在Docker上部署RocketMq主要有以下几个步骤,我是用的CenOS虚拟机,但是命令就是这几个,综合了很多大佬的文章,整理出来一个整体步骤,请大家斧正!!!
1、创建namesrv容器
创建namesrv容器时部署RocketMQ的基础,方式也很简单。
1、拉取镜像
docker pull rocketmqinc/rocketmq:4.4.0
2、新建文件夹
用于存放我们的容器位置,我的叫/home/linux。大家的需要自行设置。
mkdir /home/linux/mq
3、启动namesrv容器
docker run -d -p 9876:9876 \
--name rmqnamesrv \
--restart=always \
-v /home/linux/mq/data/namesrv/logs:/root/logs \
-v /home/linux/mq/data/namesrv/store:/root/store \
-e "MAX_POSSIBLE_HEAP=100000000" \
rocketmqinc/rocketmq:4.4.0 \
sh mqnamesrv
通过 docker 的 -v 参数使用 volume 功能,把你本地的目录映射到容器内的目录上。否则所有数据都默认保存在容器运行时的内存中,重启之后就又回到最初的起点。
2、创建broker容器
1、创建文件夹
mkdir /home/linux/mq/conf
2、在conf目录下输入命令touch broker.conf 新建文件
3、配置文件
vi broker.conf
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = {本地公网 IP} #192.168.136.131
本地公网IP就是你的Linux系统IP地址,一定要设置正确,否则后面我们的RocketMq就不会启动完成。
4、启动容器
docker run -d \
-p 10911:10911 \
-p 10909:10909 \
--name rmqbroker \
--restart=always \
-v /home/linux/mq/data/broker/logs:/root/logs \
-v /home/linux/mq/data/broker/store:/root/store \
-v /home/linux/mq/conf/broker.conf:/opt/rocketmq-4.4.0/conf/broker.conf \
--link rmqnamesrv:namesrv \
-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
broker.conf 的文件中的 brokerIP1 是你的 broker 注册到 Namesrv 中的 ip。如果不指定他会默认取容器中的内网 IP。除非你的应用也同时部署在网络相通的容器中,本地或容器外就无法连接 broker 服务了,进而导致类似 RemotingTooMuchRequestException 等各种异常。
3、安装 rocketmq 控制台
1、拉取镜像
docker pull styletang/rocketmq-console-ng
2、启动rockermq-console容器
docker run -d \
--restart=always \
--name rmqadmin \
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.136.131:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \
-p 9999:8080 \
-t styletang/rocketmq-console-ng
需要关闭防火墙或者开放namesrv和broker端口,如果不设置,控制台服务将无法访问namesrv服务
4、关闭防火墙
这一步实际上对有的同学来说是多余的,我们很多人的Linux防火墙是默认关闭的,没有必要关闭对需要的9876端口开发。
1、关闭防火墙
systemctl stop firewalld.service
2、开放指定端口
firewall-cmd --permanent --zone=public --add-port=9876/tcp
firewall-cmd --permanent --zone=public --add-port=10911/tcp
firewall-cmd --reload
5、结果
访问我们端口9876,就会出现控制台,如图所示: