环境要求:
1.linux环境
2.已安装jdk1.8
3.已安装maven
步骤一:安装jdk1.8
【精选】linux下jdk的安装和docker打包运行镜像_IT谢彪的博客-CSDN博客
步骤二:安装maven
linux下安装maven环境_xiao韭菜的博客-CSDN博客
步骤三:下载并安装RocketMQ
1.下载rocketmq
www.apache.org
2.上传到opt/rocketmq/目录下,解压 rocketmq-all-4.4.0-bin-release.zip 的源码包:
mkdir /opt/rocketmq
$ unzip rocketmq-all-4.4.0-bin-release.zip
3.安装完 RocketMQ 后,进入bin目录,启动名称服务器::
cd bin
### 启动 namesrv
nohup sh bin/mqnamesrv &### 通过jps查看启动端口
jps
### 查看日志 namesrv
tail -f ~/logs/rocketmqlogs/namesrv.log
The Name Server boot success...
4.启动(Broker)代理和查看代理
### start broker 5.x版本加上 --enable-proxy
nohup sh bin/mqbroker -n localhost:9876 &
nohup sh bin/mqbroker -n localhost:9876 --enable-proxy &### verify broker
tail -f ~/logs/rocketmqlogs/broker.log
tail -f ~/logs/rocketmqlogs/proxy.log
The broker[broker-a,192.169.1.2:10911] boot success...
5.问题描述
指令:jps查看端口,如果Broker没有启动成功,可能是虚拟机内存不足
编辑runroker.sh和runserver.sh修改默认JVM大小
# 编辑runroker.sh和runserver.sh修改默认JVM大小
vi runbroker.sh
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"
解决后需要重新启动nameServer 和 Broker
6.关闭RocketMQ
# 1.关闭NameServer
sh ./mqshutdown namesrv
# 2.关闭Broker
sh ./mqshutdown broker
步骤四:测试RocketMQ
注:需要创建两个窗口,一个用于发送,一个用于接收
1.发送消息
# 1.设置环境变量
export NAMESRV_ADDR=localhost:9876
# 2.在bin/目录下使用安装包的demo发送消息
sh tools.sh org.apache.rocketmq.example.quickstart.Producer
2.接受消息
# 1.设置环境变量
export NAMESRV_ADDR=localhost:9876
# 2.在bin/目录下使用安装包的demo发送消息
sh tools.sh org.apache.rocketmq.example.quickstart.Consumer
RocketMQ集群搭建
#所属集群名字
brokerClusterName=rocketmq-cluster
#broker名字,注意此处不同的配置文件填写的不一样
brokerName=broker-a
#0 表示 Master , >0 表示 slave
brokerId-0
#nameserver地址,分号分割
namesrvAddr=192.168.126.128:9876
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defau1tTopicQueueNums=4
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
#Broker 对外服务的监听端口
listenPort=10911
#删除文件时间点,默认凌晨 4点
deletewhen=04
#文件保留时间,默认 48 小时
fileReservedTime=48
#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#consumeQueue每个文件默认存30w条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
#存储路径
storePathRootDir=/opt/rocketmq/store
#commitLog 存储路径
storePathCommitLog=/opt/rocketmq/store/commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=/opt/rocketmq/store/consumequeue
#消息索引存储路径
storePathIndex=/opt/rocketmq/store/index
#checkpoint 文件存储路径
storeCheckpoint=/opt/rocketmq/store/checkpoint
#abort 文件存储路径
abortFile=/opt/rocketmg/store/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