RocketMq的安装-双主模式

1.修改/etc/hosts文件

[root@base-linux ~]# vi /etc/hosts
[root@base-linux ~]# systemctl restart network
[root@base-linux ~]# cat /etc/hosts

2.官网下载binary-release版本的安装包

3.上传至linux环境的/usr/local/packages/目录下

4.解压安装文件到当前文件夹,并重命名为apache-rocketmq

[root@base-linux packages]# unzip rocketmq-all-4.3.2-bin-release.zip 
[root@base-linux packages]# mv rocketmq-all-4.3.2-bin-release apache-rocketmq

5.把apache-rocketmq移动到/usr/local/src/目录下,并建立软链接

[root@base-linux ~]# cd /usr/local/packages/
#移动文件
[root@base-linux packages]# mv apache-rocketmq /usr/local/src/
[root@base-linux packages]# cd /usr/local/src/
#建立软链接
[root@base-linux src]# ln -s apache-rocketmq rocketmq

 6.创建存储路径

[root@base-linux src]# cd rocketmq/

[root@base-linux rocketmq]# mkdir store
[root@base-linux rocketmq]# mkdir store/{commitlog,consumequeue,index}

7.修改RocketMQ配置文件

[root@base-linux ~]# cd /usr/local/src/rocketmq/conf/

[root@base-linux conf]# cd 2m-noslave/

[root@base-linux 2m-noslave]# vim broker-a.properties 

[root@base-linux 2m-noslave]# vim broker-b.properties 
#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-a
#0 表示 Master,>0 表示 Slave
brokerId=0
#nameServer地址,分号分割
namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876
# 在发送消息时,自动创建服务器不存在的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/src/rocketmq/store
#commitLog 存储路径
storePathCommitLog= /usr/local/src/rocketmq/store/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/usr/local/src/rocketmq/store/consumequeue
#消息索引存储路径
storePathIndex=/usr/local/src/rocketmq/store/index
#checkpoint 文件存储路径
storeCheckpoint=/usr/local/src/rocketmq/store/checkpoint
#abort 文件存储路径
abortFile=/usr/local/src/rocketmq/store/abort
#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=ASYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

8.修改日志配置文件

#进入/usr/local/src/rocketmq/目录下,创建logs文件
[root@base-linux rocketmq]# mkdir logs

[root@base-linux rocketmq]# cd /usr/local/src/rocketmq/conf && sed -i 's#${user.home}#/usr/local/src/rocketmq#g' *.xml

9.启动namesrv (先启动两台服务器的namesrv服务,再启动broker服务)

[root@base-linux ~]# cd /usr/local/src/rocketmq/
[root@base-linux rocketmq]# cd bin/

[root@base-linux bin]# sh mqnamesrv

10. 启动BrokerServer - A节点

[root@base-linux ~]# cd /usr/local/src/rocketmq/bin/

[root@base-linux bin]# sh mqbroker -c /usr/local/src/rocketmq/conf/2m-noslave/broker-a.properties 

11.启动BrokerServer的时候,内存不足,因此需要修改jvm参数

      1.修改runbroker.sh 文件

[root@base-linux ~]# cd /usr/local/src/rocketmq/bin/
[root@base-linux bin]# vim runbroker.sh 
[root@base-linux bin]# cat runbroker.sh 

#===========================================================================================
# JVM Configuration

#JAVA_OPT="${JAVA_OPT} -server -Xms8g -Xmx8g -Xmn4g"
#===========================================================================================
JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m"

      2.修改runserver.sh文件

[root@base-linux ~]# cd /usr/local/src/rocketmq/bin/
[root@base-linux bin]# vim runserver.sh 
[root@base-linux bin]# cat runserver.sh 

#===========================================================================================
# JVM Configuration

#JAVA_OPT="${JAVA_OPT} -server -Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
#===========================================================================================
JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

      3.修改完配置文件后,重启启动

12.查看日志命令

#动态查看broker日志
[root@base-linux ~]# tail -f -n 500 /usr/local/src/rocketmq/logs/rocketmqlogs/broker.log
#动态查看namesrv日志
[root@base-linux bin]# tail -f -n 500 /usr/local/src/rocketmq/logs/rocketmqlogs/namesrv.log 

13.停止服务和数据清理

#先停止broker,再停止namesrv
[root@base-linux ~]# cd /usr/local/src/rocketmq/bin
[root@base-linux ~]# sh mqshutdown broker
[root@base-linux ~]# sh mqshutdown namesrv
#等待停止
#数据清理-删除文件后,重新创建
[root@base-linux ~]# rm -rf /usr/local/src/rocketmq/store

14.启动BrokerServer服务 -B节点

[root@base-linux ~]# cd /usr/local/src/rocketmq/bin/
#后台启动
#nohup sh mqbroker -c /usr/local/src/rocketmq/conf/2m-noslave/broker-a.properties >/dev/null 2>&1 &
[root@base-linux bin]# sh mqbroker  -c /usr/local/src/rocketmq/conf/2m-noslave/broker-b.properties 

猜你喜欢

转载自blog.csdn.net/lihongtai/article/details/84522950