全部开发者教程

企业级在线办公系统

学习本课程的部分同学用的是MacOS系统,我建议大家直接使用Docker环境安装各种数据库和消息队列。因为用Homebrew安装的MySQL、Redis通常不好用。

强烈建议大家抛弃Homebrew,因为这个工具安装的Node.js、JDK等软件,都不好用。运行前端项目跑不起来,执行后端项目,也无法运行。所以JDK、Node.js等软件一定要使用安装版。

使用M1芯片的同学,你就不用费力安装Docker了。因为Docker和Linux对M1芯片支持的不好,所以你正确的选择只有选用云主机了。在云主机上面安装Docker,然后安装各种数据库和RabbitMQ这些软件。

一、安装Docker环境

Docker是个轻量级的虚拟机软件,它只为每个虚拟环境虚拟出网卡,为每个虚拟环境分配不同的IP地址,其他硬件资源直接使用宿主机的(比如CPU资源、内存资源、硬盘资源等等),所以在电脑上面运行Docker并不会消耗太多的硬件资源。

你去Docker官网(https://docs.docker.com/desktop/)就能下载到MacOS版本的Docker安装文件,默认安装即可,无需额外设置。

安装Docker之后,我们还要给Docker设置一个加速器,要不然从国外服务器上面下载镜像文件速度太慢了,因此我们还是设置加速器,从国内服务器上面下载镜像文件吧。

网易的加速器目前是免费的,大家可以把http://hub-mirror.c.163.com地址设置上去,然后重启Docker就能使用网易的加速器了。

如果你用的是最新的Docker软件,那么控制面板上面设置加速器是这样子的。
图片描述

二、安装MySQL数据库

在命令行窗口执行下面的docker命令,在线下载MySQL镜像文件

docker pull mysql:8.0.23

创建容器的时候,我们需要把MySQL容器内的数据目录映射到MacOS系统上面。如果MySQL容器挂掉了,数据库文件不会丢失。我们新建一个MySQL容器,挂载上这个数据目录就又能正常使用MySQL了。

MySQL容器我分配内存空间是500M,如果将来觉得不够用,删除容器,再创建新容器的时候分配更大的内存。而且只要挂载上那些文件目录,MySQL的数据就不会丢失。

运行下面的命令,创建MySQL容器。-v /root/mysql/data:/var/lib/mysql这个参数设置的是把容器中MySQL的数据目录/var/lib/mysql映射到MacOS的/root/mysql/data目录上面,当然了MacOS的映射目录你也可以改成别的目录地址,通常MacOS的root目录不对普通用户开放,你自己创建两个文件夹,把这两个文件夹路径替换到命令中的/root/mysql/data/root/mysql/config,然后把目录映射到容器上。

docker run -it -d --name mysql -p 3306:3306 \
-m 500m -v /root/mysql/data:/var/lib/mysql \
-v /root/mysql/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai mysql:8.0.23 \
--lower_case_table_names=1

--name mysql这个参数定义的是MySQL容器名字,我们可以通过名字管理容器。-v /root/mysql/config:/etc/mysql/conf.d参数意味着把容器里面的MySQL配置文件目录映射MacOS系统的/root/mysql/config上面,这个映射地址可以自己修改。-e MYSQL_ROOT_PASSWORD=abc123456代表的是root帐户的密码。

三、安装MongoDB数据库

首先执行下面的命令,下载MongoDB的镜像文件

docker pull mongo:4.4.7

创建/root/mongo/mongod.conf文件,然后在文件中添加如下内容。

net:
   port: 27017
   bindIp: "0.0.0.0"

storage:
   dbPath: "/data/db"

security:
   authorization: enabled

创建容器,为MongoDB分配500M内存。刚才说过了MacOS无法使用root目录,你就换成其他的目录,自己创建个文件夹,替换下面命令行的/root/mongo路径。

docker run -it -d --name mongo -p 27017:27017 \
-v /root/mongo:/etc/mongo -m 500m \
-e MONGO_INITDB_ROOT_USERNAME=admin \
-e MONGO_INITDB_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai \
mongo:4.4.7 --config /etc/mongo/mongod.conf

四、安装Redis程序

执行命令,在线安装Redis镜像

docker pull redis:6.0.10

创建文件夹,然后在里面创建redis.conf文件,然后添加如下内容。

bind 0.0.0.0
protected-mode yes
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 0
loglevel notice
logfile ""
databases 4
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir ./
requirepass abc123456

执行命令,创建Redis容器,分配300M内存

docker run -it -d --name redis -m 300m  -p 6379:6379 \
-e TZ=Asia/Shanghai \
-v 你创建的文件夹路径:/usr/local/etc/redis redis:6.0.10 \
redis-server /usr/local/etc/redis/redis.conf

五、安装RabbitMQ

执行命令,在线安装RabbitMQ镜像

docker pull rabbitmq:3.8.9

执行命令,创建RabbitMQ容器,分配300M内存

docker run -it -d --name mq -m 300m \
-p 4369:4369 -p 5672:5672 -p 15672:15672 -p 25672:25672 \
-e TZ=Asia/Shanghai \
rabbitmq:3.8.9