登录
首页 >  文章 >  linux

Linux部署RocketMQ消息队列集群教程

时间:2026-05-15 08:18:38 137浏览 收藏

本文详细解析了在Linux环境下部署RocketMQ 5.x集群的关键避坑指南,聚焦实际生产中最易出错的四大核心环节:JDK版本严格限定为8或11(17+完全不兼容)、NameServer启动前必须手动创建日志目录且明确NAMESRV_ADDR仅用于客户端而非服务端、Broker配置中brokerIP1和namesrvAddr必须使用真实内网IP并正确配对brokerId与brokerRole以避免主从混乱、以及真正有效的集群验证必须通过mqadmin命令检查注册状态并实测消息收发——每一步都直击运维人员反复踩坑的痛点,帮你绕过“看似启动成功却无法收发消息”的假象,快速构建稳定可靠的高可用消息队列集群。

Linux系统安装配置RocketMQ 消息队列集群部署

启动 NameServer 前必须确认 Java 环境和日志目录

RocketMQ 5.x 全版本依赖 JDK 8 或 JDK 11,java -version 输出必须显示 1.8.11. 开头;JDK 17+ 不兼容。没配好会卡在 Exception in thread "main" java.lang.UnsupportedClassVersionError

日志路径默认是 ~/logs/rocketmqlogs/,但很多用户解压后直接运行,目录不存在会导致启动无声失败。务必手动创建:

mkdir -p ~/logs/rocketmqlogs/

另外,NAMESRV_ADDR 环境变量不是启动 NameServer 所需的,它是给 Producer/Consumer 用的——NameServer 自己不读这个变量。

Broker 启动失败常见于 broker.conf 缺失或 IP 配置错误

二进制包(如 rocketmq-all-5.3.2-bin-release.zip)自带默认配置,但默认监听 127.0.0.1,外网无法访问;源码编译包则根本没配 broker.conf,直接启动会报 No such file or directory

正确做法是显式指定配置文件并填对本机 IP:

echo "brokerIP1=192.168.1.100
namesrvAddr=192.168.1.100:9876
brokerName=broker-a
brokerId=0
deleteWhen=04
fileReservedTime=48
brokerRole=ASYNC_MASTER
flushDiskType=ASYNC_FLUSH" > conf/broker.conf
  • brokerIP1 必须写真实内网 IP,不能写 0.0.0.0 或主机名
  • namesrvAddr 要跟实际 NameServer 启动地址一致,多个用分号隔开
  • 若用多 Master 模式,每台机器的 brokerName 必须不同(如 broker-abroker-b

集群模式下 brokerIdbrokerRole 必须成对设置

单节点测试时设 brokerId=0 + brokerRole=ASYNC_MASTER 就行;但部署 2m-2s 集群时,每对 Master-Slave 的 brokerName 相同,brokerId 必须不同:

Master 节点:brokerId=0brokerRole=SYNC_MASTER(或 ASYNC_MASTER

对应 Slave 节点:brokerId=1brokerRole=SLAVE

漏掉 brokerRole=SLAVE 或把 Slave 的 brokerId 也设成 0,会导致 Slave 启动后注册为另一个 Master,NameServer 日志里会出现重复 broker-a 注册,Consumer 拉取队列时行为异常。

同步双写要求 flushDiskType=SYNC_FLUSH + brokerRole=SYNC_MASTER 同时生效,缺一不可。

验证集群是否真正就绪,别只看日志里的 “boot success”

tail -f ~/logs/rocketmqlogs/namesrv.log 出现 The Name Server boot success 只代表进程起来了;proxy.logbroker.log 里有 boot success 也不代表能收发消息。

真正有效的验证方式只有两个:

  • 执行 ./bin/mqadmin clusterList -n 192.168.1.100:9876,输出里必须包含所有预期的 brokerName,且 Broker 列状态为 OK
  • ./bin/tools.sh org.apache.rocketmq.example.quickstart.Producer 发一条消息,再用 ./bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer 拉出来——这步必须在目标机器上跑,不能只在本地跑

很多人卡在 Consumer 收不到消息,其实是 NAMESRV_ADDR 没导到 Consumer 进程环境里,或者防火墙拦了 10911(Broker 默认端口)、9876(NameServer 端口)。

今天关于《Linux部署RocketMQ消息队列集群教程》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>