在Docker上面部署RocketMQ

在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,就会出现控制台,如图所示:

在Docker上面部署RocketMQ_第1张图片

你可能感兴趣的:(Linxu,docker,Rocketmq,消息队列)