docker部署rockectmq
1,安装RocketMQ
拉取镜像
docker pull rocketmqinc/rocketmq
1.1,部署NameServer
安装
docker run -d --restart=always --name rmqnamesrv --privileged=true -p 9876:9876 -v /mydata/rocketmq/data/namesrv/logs:/root/logs -v /mydata/rocketmq/data/namesrv/store:/root/store -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq sh mqnamesrv
参数说明
| 参数 | 说明 |
-d
|
以守护进程的方式启动 |
--restart=always
|
docker重启时容器自动重启 |
--name rmqnamesrv
|
将容器的名称设置为rmqnamesrv |
-p 9876:9876
|
把容器内的端口9876挂载到宿主机9876上面 |
-v /mydata/rocketmq/data/namesrv/logs:/root/logs
|
日志目录挂载 |
-v /mydata/rocketmq/data/namesrv/store:/root/store
|
存储目录挂载 |
-e "MAX_POSSIBLE_HEAP=100000000"
|
设置容器最大堆内存为100000000 |
rocketmqinc/rocketmq
|
使用的镜像名称 |
sh mqnamesrv
|
启动namesrv |
1.2,部署Broker
创建broker.conf配置
vi /mydata/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.56.100
#剩余磁盘比例
diskMaxUsedSpaceRatio=85
安装
docker run -d --restart=always --name rmqbroker --link rmqnamesrv:namesrv -p 10911:10911 -p 10909:10909 --privileged=true -v /mydata/rocketmq/data/broker/logs:/root/logs -v /mydata/rocketmq/data/broker/store:/root/store -v /mydata/rocketmq/conf/broker.conf:/opt/rocketmq-4.4.0/conf/broker.conf -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf
相关参数说明
| 参数 | 说明 |
-d |
以守护进程的方式启动 |
--restart=always |
docker重启时容器自动重启 |
--name rmqbroker |
将容器的名称设置为rmqbroker |
--link rmqnamesrv:namesrv |
和rmqnamesrv容器通信 |
-p 10911:10911 |
把容器内的端口10911挂载到宿主机10911上面 |
-p 10909:10909 |
把容器内的vip通道挂载到宿主机 |
-e "NAMESRV_ADDR=namesrv:9876" |
指定namesrv地址为本机namesrv的地址 |
-v /mydata/rocketmq/data/namesrv/logs:/root/logs |
日志目录挂载 |
-v /mydata/rocketmq/data/namesrv/store:/root/store |
存储目录挂载 |
-e "MAX_POSSIBLE_HEAP=200000000" |
指定broker服务的最大堆内存 |
rocketmqinc/rocketmq |
使用的镜像名称 |
sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf |
指定配置文件启动broker节点 |
2,安装控制台
拉取镜像
docker pull pangliang/rocketmq-console-ng
控制台安装
docker run -d --restart=always --name rmqadmin -e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.56.100:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8080:8080 pangliang/rocketmq-console-ng
3,验证
查看容器启动情况

访问测试


浙公网安备 33010602011771号