RocketMQ集群搭建(实例)

网上很多搭建RocketMQ的教程,但是在楼主的疯狂百度以及疯狂采坑下,终于成功的搭建了一个RocketMQ的集群(LingZsj真的是太难了啊~.~)

废话不多说开始搭建集群了

咋们搭建一个多master多slave模式(同步)的集群,这边条件有限只有两台服务器(所以我们的集群就是一个双主双从的集群架构模式了)

  首先说明下这边我直接写Linux命令,目的很简单就是为了能让一个 从未搭建过RocketMQ的小白也能通过复制粘贴搭建出一个属于自己的集群

 

ps:安装JDK的运行环境是必须的应为RokcetMQ是利用java语言来写的所以他必须依赖jdk来运行所以我们要先在两台服务器上分别安装jdk

cd /usr/local

mkdir javaJdk

cd javaJdk

#将下载好的jdk传输到服务器上
#传输好了解压缩下
tar -zxvf jdk-8u271-linux-x64.tar.gz

#删掉JDK压缩包
rm -rf jdk-8u271-linux-x64.tar.gz

配置jdk的运行环境

vim /etc/profile

#jd环境配置部分
export JAVA_HOME=/usr/local/javaJdk/jdk1.8.0_271

export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib:$CLASSPATH
export JAVA_PATH=${JAVA_HOME}/bin:${JRE_HOME}/bin
export PATH=$PATH:${JAVA_PATH}

 

#保存文件

esc

:

wq

 

 

重新加载一次文件

source /etc/profile

 

 

1.修改网卡环境

cd /etc/hosts    (下面是host的配置文件部分,同样的配置在第二台服务器也粘贴一次)

两台服务器一下分别是两台服务器的ip地址
# nameserver xx.xxx.xx.xx1 rocketmq-nameserver1 xx.xxx.xx.xx2 rocketmq-nameserver2 # broker xx.xxx.xx.xx1 rocketmq-master1 xx.xxx.xx.xx1 rocketmq-slave2 xx.xxx.xx.xx2 rocketmq-master2 xx.xxx.xx.xx2 rocketmq-slave1

 

2.重启网卡(第二台服务器同样)

systemctl restart network

ps;这边说下的第一个坑了,由于该服务器上有一堆docker服务(服务未投入生产)所以重启网卡后服务会出现连接不上的问题,问题不大重启docker服务即可然后在重启需要的容器(别傻乎乎的去重启服务器)

希望(shutdown -r now   立即重启) 这个命令你不会用到

 

3.关闭Linux服务器的防火墙(第二台同样)

# 关闭防火墙
systemctl stop firewalld.service 
# 查看防火墙的状态
firewall-cmd --state 
# 禁止firewall开机启动
systemctl disable firewalld.service

或者为了安全,只开放特定的端口号,RocketMQ默认使用3个端口:9876 、10911 、11011 。如果防火墙没有关闭的话,那么防火墙就必须开放这些端口:
# 开放name server默认端口
firewall-cmd --remove-port=9876/tcp --permanent
# 开放master默认端口
firewall-cmd --remove-port=10911/tcp --permanent
# 开放slave默认端口 (当前集群模式可不开启)
firewall-cmd --remove-port=11011/tcp --permanent 
# 重启防火墙
firewall-cmd --reload

 4.创建文件夹

cd /usr/local

#创建rocketmq文件夹 mkdir rocketmq

#进入到rocketmq文件夹内 cd rocketmq/

 

5.官网下载rockerMQ的安装包(这边下载二进制安装包)

官网链接地址:http://rocketmq.apache.org/dowloading/releases/    ---这边我下载的是4.4.0版本的

 

6.将下载的文件上传到rocketmq文件夹上(服务2也需要)

 

7.解压缩zip文件(服务2也需要)

unzip rocketmq-all-4.4.0-bin-release.zip

 

8.删掉安装包这边(这步不建议你们跟我一样写,自己斟酌)

rm -rf rocketmq-all-4.4.0-bin-release.zip

 

9.创建集群需要的文件夹

#主节点文件的存储路径
mkdir /usr/local/rocketmq/mstore
mkdir /usr/local/rocketmq/mstore/commitlog
mkdir /usr/local/rocketmq/mstore/consumequeue
mkdir /usr/local/rocketmq/mstore/index

#从节点服务服务器的文件存储路径
mkdir /usr/local/rocketmq/store
mkdir /usr/local/rocketmq/store/commitlog
mkdir /usr/local/rocketmq/store/consumequeue
mkdir /usr/local/rocketmq/store/index

 

10.xx.xxx.xx.xx1服务器的broker-a.properties配置文件

#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-a
#0 表示 Master,>0 表示 Slave
brokerId=0
#nameServer地址,分号分割
namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876
#配置外网连接地址
brokerIP1 = xx.xxx.xx.xx1
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
#Broker 对外服务的监听端口
listenPort=10911
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=120
#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
#存储路径
storePathRootDir=/usr/local/rocketmq/mstore
#commitLog 存储路径
storePathCommitLog=/usr/local/rocketmq/mstore/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/usr/local/rocketmq/mstore/consumequeue
#消息索引存储路径
storePathIndex=/usr/local/rocketmq/mstore/index
#checkpoint 文件存储路径
storeCheckpoint=/usr/local/rocketmq/mstore/checkpoint
#abort 文件存储路径
abortFile=/usr/local/rocketmq/mstore/abort
#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=SYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=SYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

11.xx.xxx.xx.xx1的broker-b-s.properties文件配置

#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-b
#0 表示 Master,>0 表示 Slave
brokerId=1
#nameServer地址,分号分割
namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876
#配置外网连接地址
brokerIP1 = xx.xxx.xx.xx1
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
#Broker 对外服务的监听端口
listenPort=11011
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=120
#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
#存储路径
storePathRootDir=/usr/local/rocketmq/store
#commitLog 存储路径
storePathCommitLog=/usr/local/rocketmq/store/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/usr/local/rocketmq/store/consumequeue
#消息索引存储路径
storePathIndex=/usr/local/rocketmq/store/index
#checkpoint 文件存储路径
storeCheckpoint=/usr/local/rocketmq/store/checkpoint
#abort 文件存储路径
abortFile=/usr/local/rocketmq/store/abort
#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=SLAVE
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

 

12.xx.xxx.xx.xx2服务器的broker-b,properties文件的配置

#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-b
#0 表示 Master,>0 表示 Slave
brokerId=0
#nameServer地址,分号分割
namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876
#配置外网连接地址
brokerIP1 = xx.xxx.xx.xx2
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
#Broker 对外服务的监听端口
listenPort=10911
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=120
#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
#存储路径
storePathRootDir=/usr/local/rocketmq/mstore
#commitLog 存储路径
storePathCommitLog=/usr/local/rocketmq/mstore/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/usr/local/rocketmq/mstore/consumequeue
#消息索引存储路径
storePathIndex=/usr/local/rocketmq/mstore/index
#checkpoint 文件存储路径
storeCheckpoint=/usr/local/rocketmq/mstore/checkpoint
#abort 文件存储路径
abortFile=/usr/local/rocketmq/mstore/abort
#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=SYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=SYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

13.xx.xxx.xx.xx2中的broker-a-s,properties文件配置

#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-a
#0 表示 Master,>0 表示 Slave
brokerId=1
#nameServer地址,分号分割
namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876
#配置外网连接地址
brokerIP1 = xx.xxx.xx.xx2
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
#Broker 对外服务的监听端口
listenPort=11011
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=120
#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
#存储路径
storePathRootDir=/usr/local/rocketmq/store
#commitLog 存储路径
storePathCommitLog=/usr/local/rocketmq/store/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/usr/local/rocketmq/store/consumequeue
#消息索引存储路径
storePathIndex=/usr/local/rocketmq/store/index
#checkpoint 文件存储路径
storeCheckpoint=/usr/local/rocketmq/store/checkpoint
#abort 文件存储路径
abortFile=/usr/local/rocketmq/store/abort
#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=SLAVE
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

ps:这边说下master节点的文件夹和slave文件的文件夹为什么要分别创建应为公用一个问件加master服务能起来但是slave服务时起不来的(不信可以去试试)

15.修改启动脚本文件(两台服务都修改)

cd /usr/local/rockermq/rocketmq-all-4.4.0-bin-release/bin

vi runbroker.sh

-------文件配置如下-------
# 开发环境配置 JVM Configuration
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m"

vi runserver.sh
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

 

启动服务

进入到rocketmq的安装包内
cd /usr/local/rockermq/rocketmq-all-4.4.0-bin-release/bin ls

#首先分别启动两台服务器(xx.xxx.xx.xx1)的namesrv服务
nohup sh mqnamesrv & (&不能掉)
xx.xxx.xx.xx2的namesrv服务
nohup sh mqnamesrv &    (&不能掉)


#启动xx.xxx.xx.xx1的master节点服务
nohup sh mqbroker -c /usr/local/rocketmq/
rocketmq-all-4.4.0-bin-release/conf/2m-2s-sync/broker-a.properties &

#启动slave服务
nohup sh mqbroker -c /usr/local/rocketmq/rocketmq-all-4.4.0-bin-release/conf/2m-2s-sync/broker-b-s.properties &


#启动xx.xxx.xx.xx2
nohup sh mqbroker -c /usr/local/rocketmq/rocketmq-all-4.4.0-bin-release/conf/2m-2s-sync/broker-b.properties &

#启动slave服务
nohup sh mqbroker -c /usr/local/rocketmq/rocketmq-all-4.4.0-bin-release/conf/2m-2s-sync/broker-a-s.properties &

16.利用jps查看下(安装了jdk就能用--下图表示成功)

 

17.停止namesrv和broker服务

namesrv服务(停止)
sh  mqshutdown namesrv

broker服务(停止)
sh mqshutdown broker

 

 18.安装rocketmq-console控制台

利用docker安装控制台就好了

直接运行如下命令就好了

docker pull styletang/rocketmq-console-ng

安装镜像:
docker run -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=xx.xxx.xx.xx1:9876;xx.xxx.xx.xx2:9876 -Drocketmq.config.isVIPChannel=false" -p 9326:8080 -t styletang/rocketmq-console-ng

好了这就装好了~~

上图:(ok了)

 

posted @ 2020-12-15 17:44  LingZSJ  阅读(1494)  评论(1编辑  收藏  举报