在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. 打开终端并运行Docker。 2. 运行以下命令以获取最新版本的RocketMQ镜像: ``` docker pull rocketmqinc/rocketmq:latest ``` 如果您需要特定版本的RocketMQ,请将“latest”更改为所需的版本号。 3. 等待下载完成后,您可以使用以下命令查看已下载的镜像列表: ``` docker images ``` 在这个列表中,您应该能够看到刚刚下载的RocketMQ镜像。 要在Docker部署RocketMQ,可以按照以下步骤操作: 1. 创建一个名为“rocketmq”的网络: ``` docker network create rocketmq ``` 2. 运行一个名为“namesrv”的RocketMQ NameServer容器: ``` docker run --name namesrv --network rocketmq -e "MAX_POSSIBLE_HEAP=100000000" -p 9876:9876 rocketmqinc/rocketmq:latest sh mqnamesrv ``` 3. 运行一个名为“broker”的RocketMQ Broker容器: ``` docker run --name broker --network rocketmq -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=2000000000" -p 10911:10911 -p 10909:10909 rocketmqinc/rocketmq:latest sh mqbroker -c /opt/rocketmq-4.9.0/conf/broker.conf ``` 在这个命令中,“NAMESRV_ADDR”环境变量设置为NameServer的地址和端口,而“MAX_POSSIBLE_HEAP”环境变量设置为Broker容器最大可用堆内存大小。请注意,这里我们使用了一个特定版本的RocketMQ(4.9.0),您应该将此命令中的版本号更改为您下载的版本。 4. 现在,您应该能够通过访问“http://localhost:9876”来访问NameServer的控制台,并通过访问“http://localhost:10909”来访问Broker的控制台。 请注意,这些命令只是一个简单的示例,您可以根据您的需求进行修改。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值