firewall-cmd --zone=public --add-port=9876/tcp --permanent firewall-cmd --zone=public --add-port=10911/tcp --permanent firewall-cmd --zone=public --add-port=9800/tcp --permanent firewall-cmd --reload1.2.创建存储文件夹
mkdir -p /root/rocketmq/data/namesrv/logs /root/rocketmq/data/namesrv/store /root/rocketmq/conf /root/rocketmq/data/broker/logs /root/rocketmq/data/broker/store1.3.进入到 /root/rocketmq/conf 文件夹下 创建文件 broker.conf后面创建broker节点使用该配置
cd /root/rocketmq/conf touch broker.conf1.4.编辑 broker.conf 文件
vi broker.conf1.5.加入以下配置 {}括号内需要换成自己服务器的外网IP(输入ip后不带括号)
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = {本地外网 IP}
1.6.拉取镜像
docker pull rocketmqinc/rocketmq docker pull styletang/rocketmq-console-ng2.创建 Namesrv 容器
2.1运行创建容器命令NameServer 是一个功能齐全的服务器,主要包括两个功能:
- Broker 管理,NameServer接受来自 Broker 集群的注册,并提供心跳机制来检查 Broker 是否处于活动状态。
- 路由管理,每个 NameServer 将保存有关代理集群的完整路由信息和客户端查询的队列信息。
docker run -d -p 9876:9876 -v /root/rocketmq/data/namesrv/logs:/root/logs -v /root/rocketmq/data/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq sh mqnamesrv2.2启动容器
docker start rmqnamesrv2.3查看容器时候启动
docker ps
可以看到 Namesrv 已经启动了
3.创建 Broker容器3.1运行创建容器命令Broker Server 负责消息的存储和传递、消息查询、HA 保证等。
docker run -d -p 10911:10911 -p 10909:10909 -v /root/rocketmq/data/broker/logs:/root/logs -v /root/rocketmq/rocketmq/data/broker/store:/root/store -v /root/rocketmq/conf/broker.conf:/opt/rocketmq/conf/broker.conf --name rmqbroker --link rmqnamesrv:namesrv -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq sh mqbroker -c /opt/rocketmq/conf/broker.conf3.2启动容器
docker start rmqbroke3.3查看容器时候启动
docker ps3.4.创建 console控制台 容器
运行创建容器命令
docker run -d --name rmqconsole -p 9800:8080 -e "JAVA_OPTS=-Drocketmq.namesrv.addr=namesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -t styletang/rocketmq-console-ng3.5等下载完毕启动容器
docker startr mqconsole
3.6查看容器时候启动docker ps
访问 外网IP:9800 进入控制台
进入之后 未弹出报错说明 namesrv 连接成功



