三 Linux 主机 配置 docker 一键启动 rocketMQ 集群

本贴最后更新于 1837 天前,其中的信息可能已经时过境迁

本次使用 docker 配置三 master 三 slave 的 rocketmq 集群

image.png

开工前准备:

三台 centos 服务器/虚拟机
搭建 docker+docker-compose 环境
开放防火墙(或者自行开放相应端口)

配置 rocket 本地映射目录

运行脚本
三台机器分别运行脚本

mkdir -p  /opt/rocketmq/logs/nameserver-1  
mkdir -p  /opt/rocketmq/logs/nameserver-2  
mkdir -p /opt/rocketmq/store/nameserver-1  
mkdir -p /opt/rocketmq/store/nameserver-2  
mkdir -p /opt/rocketmq/logs/broker-1  
mkdir -p /opt/rocketmq/logs/broker-2  
mkdir -p /opt/rocketmq/store/broker-1  
mkdir -p /opt/rocketmq/store/broker-2  
mkdir -p /home/rocketmq/broker-1  
mkdir -p /home/rocketmq/broker-2  
  
mkdir -p  /opt/rocketmq/logs/nameserver-3  
mkdir -p  /opt/rocketmq/logs/nameserver-4  
mkdir -p /opt/rocketmq/store/nameserver-3  
mkdir -p /opt/rocketmq/store/nameserver-4  
mkdir -p /opt/rocketmq/logs/broker-3  
mkdir -p /opt/rocketmq/logs/broker-4  
mkdir -p /opt/rocketmq/store/broker-3  
mkdir -p /opt/rocketmq/store/broker-4  
mkdir -p /home/rocketmq/broker-3  
mkdir -p /home/rocketmq/broker-4  
  
mkdir -p  /opt/rocketmq/logs/nameserver-5  
mkdir -p  /opt/rocketmq/logs/nameserver-6  
mkdir -p /opt/rocketmq/store/nameserver-5  
mkdir -p /opt/rocketmq/store/nameserver-6  
mkdir -p /opt/rocketmq/logs/broker-5  
mkdir -p /opt/rocketmq/logs/broker-6  
mkdir -p /opt/rocketmq/store/broker-5  
mkdir -p /opt/rocketmq/store/broker-6  
mkdir -p /home/rocketmq/broker-5  
mkdir -p /home/rocketmq/broker-6  

分别配置三台机器的 broker.conf

配置文件的文件夹存放在 /home/rocketmq 目录下
以 os1 的配置为例
master

brokerClusterName = rocketmq-cluster  
brokerName = broker-a-master  
brokerId = 1  
#这个很有讲究 如果是正式环境 这里一定要填写内网地址(安全)  
#如果是用于测试或者本地这里建议要填外网地址,因为你的本地代码是无法连接到阿里云内网,只能连接外网。  
brokerIP1 = 10.10.20.197  
deleteWhen = 04  
fileReservedTime = 48  
brokerRole = ASYNC_MASTER  
flushDiskType = ASYNC_FLUSH  
# 内网的(阿里云有内网IP和外网IP)  
namesrvAddr=10.10.20.197:9876;10.10.20.198:9876;10.10.20.199:9876  
autoCreateTopicEnable=true  
#Broker 对外服务的监听端口,  
listenPort = 10911  
#Broker角色  
#- ASYNC_MASTER 异步复制Master  
#- SYNC_MASTER 同步双写Master  
#- SLAVE  
brokerRole=ASYNC_MASTER  
#刷盘方式  
#- ASYNC_FLUSH 异步刷盘  
#- SYNC_FLUSH 同步刷盘  
flushDiskType=ASYNC_FLUSH  
  

slave

brokerClusterName = rocketmq-cluster  
brokerName = broker-c-slave  
brokerId = 2  
brokerIP1 = 10.10.20.197  
deleteWhen = 04  
fileReservedTime = 48  
brokerRole = ASYNC_MASTER  
flushDiskType = ASYNC_FLUSH  
# 内网的(阿里云有内网IP和外网IP)  
namesrvAddr=10.10.20.197:9876;10.10.20.198:9876;10.10.20.199:9876  
autoCreateTopicEnable=true  
#Broker 对外服务的监听端口,  
listenPort = 10909  
#Broker角色  
#- ASYNC_MASTER 异步复制Master  
#- SYNC_MASTER 同步双写Master  
#- SLAVE  
brokerRole=SLAVE  
#刷盘方式  
#- ASYNC_FLUSH 异步刷盘  
#- SYNC_FLUSH 同步刷盘  
flushDiskType=ASYNC_FLUSH  
  

编写 docker-compose.yml

cd /home/rocketmq  
touch docker-compose.yml  
vi docke-compose.yml  
version: '3.5'  
services:  
 rmqnamesrv-a:  
 image: rocketmqinc/rocketmq:4.3.0  
 container_name: rmqnamesrv-a  
 ports:  
 - 9876:9876  
 volumes:  
 - /opt/rocketmq/logs/nameserver-a:/opt/logs  
 - /opt/rocketmq/store/nameserver-a:/opt/store  
 command: sh mqnamesrv  
 networks:  
 rmq:  
 aliases:  
 - rmqnamesrv-a  
  
 rmqbroker-a-master:  
 image: rocketmqinc/rocketmq:4.3.0  
 container_name: rmqbroker-a-master  
 ports:  
 - 10911:10911  
 volumes:  
 - /opt/rocketmq/logs/broker-1:/opt/logs  
 - /opt/rocketmq/store/broker-1:/opt/store  
 - /home/rocketmq/broker-1/broker-1.conf:/opt/rocketmq-4.3.0/conf/broker.conf   
 environment:  
 TZ: Asia/Shanghai  
 NAMESRV_ADDR: "10.10.20.197:9876;10.10.20.198:9876;10.10.20.199:9876"  
 JAVA_OPTS: " -Duser.home=/opt"  
 JAVA_OPT_EXT: "-server -Xms256m -Xmx256m -Xmn256m"  
 command: sh mqbroker -c /opt/rocketmq-4.3.0/conf/broker.conf autoCreateTopicEnable=true &  
 links:  
 - rmqnamesrv-a:rmqnamesrv-a  
 networks:  
 rmq:  
 aliases:  
 - rmqbroker-a-master  
  
 rmqbroker-c-slave:  
 image: rocketmqinc/rocketmq:4.3.0  
 container_name: rmqbroker-c-slave  
 ports:  
 - 10909:10909  
 volumes:  
 - /opt/rocketmq/logs/broker-2:/opt/logs  
 - /opt/rocketmq/store/broker-2:/opt/store  
 - /home/rocketmq/broker-2/broker-2.conf:/opt/rocketmq-4.3.0/conf/broker.conf   
 environment:  
 TZ: Asia/Shanghai  
 NAMESRV_ADDR: "10.10.20.197:9876;10.10.20.198:9876;10.10.20.199:9876"  
 JAVA_OPTS: " -Duser.home=/opt"  
 JAVA_OPT_EXT: "-server -Xms256m -Xmx256m -Xmn256m"  
 command: sh mqbroker -c /opt/rocketmq-4.3.0/conf/broker.conf autoCreateTopicEnable=true &  
 links:  
 - rmqnamesrv-a:rmqnamesrv-a  
 networks:  
 rmq:  
 aliases:  
 - rmqbroker-c-slave  
 rmqconsole:  
 image: styletang/rocketmq-console-ng  
 container_name: rmqconsole  
 ports:  
 - 8080:8080  
 environment:  
 JAVA_OPTS: -Drocketmq.namesrv.addr=10.10.20.197:9876;10.10.20.198:9876;10.10.20.199:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false  
 networks:  
 rmq:  
 aliases:  
 - rmqconsole  
networks:  
 rmq:  
 name: rmq  
 driver: bridge  
  

通过 Docker 总共拉取了 4 条镜像记录。rmqnamesrv-armqbroker-a-masterrmqbroker-c-slavermqconsole
rmqconsole是一个可视化的工具,可以通过页面来查看 RocketMQ 相关信息
可以看出对于 broker 的配置文件 broker.conf 已经被 broker-1/2.conf 替换

全部配置文件可以参考下载文件 ❤️
下载链接 提取码: d54d

一键启动

进入 /home/rocketmq 目录

docker-compose -f docker-compose.yml up -d  

启动成功可以进入 http://OS1/2/3 的 ip:8080/#/
查看是否成功集群
image.png

  • RocketMQ
    22 引用 • 10 回帖
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    492 引用 • 926 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...