部署mysql
以5.7为例
- Dokcer pull mysql:5.7
- 创建目录,用于挂载容器内数据文件: xxx/docker/mysql/data、 xxx/docker/mysql/logs、 xxx/docker/mysql/conf
- 执行命令
docker run -d -p 3306:3306 --name mysql \
-e MYSQL_ROOT_PASSWORD=root \
-v xxx/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf \
-v xxx/docker/mysql/data:/var/lib/mysql \
mysql:5.7
8.0版本需要多一个挂载目录,否则会报错: Error on realpath() on ‘/var/lib/mysql-files’ (Error 2 - No such file or directory
-v xxx/docker/mysql/mysql-files:/var/lib/mysql-files
其次,8.0需要开启远程连接,否则127.0.0.1:3306 无法连接
//1.登录mysql
mysql -uroot -p
//2.对root用户进行授权
GRANT ALL ON *.* TO 'root'@'%';
//3.刷新权限
flush privileges;
注意: -v 为指定挂载目录 冒号前面是指定目录,冒号后面是容器内部目录
部署redis
以6.2为例
- Dokcer pull redis:6.2
- 创建目录,用于挂载容器内数据文件: xxx/docker/redis/data、 xxx/docker/redis/conf
- 创建redis.conf文件 可在官网下载,类似于nginx把配置文件放到宿主机上,方便进行修改
官网下载conf文件地址:https://redis.io/docs/manual/config/ (也可先运行一个redis容器,然后拷贝到宿主机使用,再次创建容器即可) - 执行命令
docker run -it -d -p 6379:6379 --name redis \
-v xxx/docker/redis/conf/redis.conf:/etc/redis/redis.conf \
-v xxx/docker/redis/data:/data \
redis:6.2 \
redis-server /etc/redis/redis.conf \
--appendonly yes
关于本地链接redis失败问题:
有一个前提:在docker部署redis时指定了挂载目录(不指定挂载目录是可以直接通过127.0.0.1:6379连接的),和两个因素:
- 配置文件中的bind命令
bind 127.0.0.1
- 配置文件中的命令
protected-mode yes
目前我所知道的解决方法针对于某些版本:
- 针对6.2版本,两个方式 ①是把
bind 127.0.0.1
改为bind 0.0.0.0
,②是把protected-mode yes
改为protected-mode no
,这两个任意一项都可以使127.0.0.1连接成功 - 针对7.0版本,需要把
bind 127.0.0.1
注释掉,并且把protected-mode yes
改为protected-mode no
才可以使127.0.0.1连接成功
具体的原理原因,可以自行查阅redis配置的绑定IP地址,和关闭保护模式。
注意: -v 为指定挂载目录 冒号前面是指定目录,冒号后面是容器内部目录
部署MongoDB
以5.0为例
- Dokcer pull mongo::5.0
- 创建目录,用于挂载容器内数据文件: xxx/docker/mongo/data
- 执行命令
docker run -d --name mongodb \
-v xxx/docker/mongo/data:/data \
-p 27017:27017 \
-e MONGO_INITDB_ROOT_USERNAME=admin \
-e MONGO_INITDB_ROOT_PASSWORD=admin \
--privileged=true \
mongo:5.0
部署Rocketmq
部署namesrv
- 拉取镜像:
docker pull rocketmqinc/rocketmq
-
创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/namesrv/logs、xxx/docker/rocketmq/data/namesrv/store
-
执行命令
docker run -d \
--restart=always \
--name rmqnamesrv \
-p 9876:9876 \
-v ~/docker/rocketmq/data/namesrv/logs:/root/logs \
-v ~/docker/rocketmq/data/namesrv/store:/root/store \
-e "MAX_POSSIBLE_HEAP=100000000" \
foxiswho/rocketmq \
sh mqnamesrv
部署broker
-
镜像与namesrv使用的是相同,不需要拉取
-
创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/broker/logs、xxx/docker/rocketmq/data/broker/store、 xxx/docker/rocketmq/conf
-
创建配置文件:broker.conf
# 所属集群名称,如果节点较多可以配置多个
brokerClusterName = DefaultCluster
#broker名称,master和slave使用相同的名称,表明他们的主从关系
brokerName = broker-a
#0表示Master,大于0表示不同的slave
brokerId = 0
#表示几点做消息删除动作,默认是凌晨4点
deleteWhen = 04
#在磁盘上保留消息的时长,单位是小时
fileReservedTime = 48
#有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机制;
brokerRole = ASYNC_MASTER
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH
# broker节点所在服务器的ip地址
brokerIP1 = 192.168.100.9
# docker内部容器namesrvAddr地址
namesrvAddr= 172.17.0.6:9876
- 执行命令
docker run -d \
--restart=always \
--name rmqbroker \
--link rmqnamesrv:namesrv \
-p 10911:10911 \
-p 10909:10909 \
-v ~/docker/rocketmq/data/broker/logs:/root/logs \
-v ~/docker/rocketmq/data/broker/store:/root/store \
-v ~/docker/rocketmq/conf/broker.conf:/docker/rocketmq/conf/broker.conf \
-e "NAMESRV_ADDR=namesrv:9876" \
-e "MAX_POSSIBLE_HEAP=200000000" \
rocketmqinc/rocketmq \
sh mqbroker -c /docker/rocketmq/conf/broker.conf
创建rockermq-console
- 拉取镜像:
docker pull styletang/rocketmq-console-ng
-
创建目录,用于挂载容器内数据文件: xxx/docker/rocketmq/data/namesrv/logs、xxx/docker/rocketmq/data/namesrv/store
-
执行命令,这里的地址是docker内部容器namesrvAddr地址与配置文件保持一直
docker run \
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.17.0.6:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \
-p 8080:8080 \
-t styletang/rocketmq-console-ng \
--restart=always \
--name rmqadmin
访问localhost:8090/ ,即可查看部署好的mq信息
追加自动重启命令
docker update --restart=always 容器名, 最多重启三次策略: --restart=on-failure:3