Docker部署RocketMQ小记

89 阅读1分钟

前言

经本人多次尝试,验证可行,仅做学习记录。

安装rocketmq和rocketmq-console

docker pull rocketmqinc/rocketmq:4.4.0
docker pull styletang/rocketmq-console-ng

初始化文件夹和配置文件

//供namesrv服务使用
mkdir -p  /docker/rocketmq/data/namesrv/logs   
mkdir -p  /docker/rocketmq/data/namesrv/store
//供broker服务使用
mkdir -p  /docker/rocketmq/data/broker/logs   
mkdir -p  /docker/rocketmq/data/broker/store 
mkdir -p  /docker/rocketmq/conf

初始化配置文件,在/docker/rocketmq/conf目录下新建一个配置文件

vim /docker/rocketmq/conf/broker.conf
内容如下
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = 宿主机的ip

依次创建[namesrv]>>[broker]>>[rockermq-console]容器

1.创建namesrv容器并运行
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" \
rocketmqinc/rocketmq:4.4.0 \
sh mqnamesrv
2. 创建broker容器并运行
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:/opt/rocketmq-4.4.0/conf/broker.conf \
-e "NAMESRV_ADDR=namesrv:9876" \
-e "MAX_POSSIBLE_HEAP=200000000" \
rocketmqinc/rocketmq:4.4.0 \
sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf
3. 创建rockermq-console容器并运行
docker run -d \
--restart=always \
--name rmqconsoleng \
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.52.136:9876 
-Dcom.rocketmq.sendMessageWithVIPChannel=false" \
-p 9999:8080 \
styletang/rocketmq-console-ng

最终效果

http://宿主机ip:9999/

image.png