学习本课程的部分同学用的是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