Centos9安装rocketmq

准备工作

安装 Java 环境:RocketMQ 需要 Java 运行环境(JDK 1.8 或更高版本)。

bash 复制代码
sudo dnf install -y java-17-openjdk-devel  # 或者 java-1.8.0-openjdk-devel
java -version  # 验证安装

防火墙配置:如果系统防火墙开启,需开放 RocketMQ 相关端口。

bash 复制代码
sudo firewall-cmd --permanent --add-port=9876/tcp  # Nameserver 默认端口
sudo firewall-cmd --permanent --add-port=10909/tcp --add-port=10911/tcp  # Broker 默认端口
sudo firewall-cmd --reload
# 如需后续使用控制台,还需开放其端口(如 8080)

二进制包安装(推荐用于生产环境)

下载并解压 RocketMQ : 访问 RocketMQ 下载页面 获取最新的二进制包下载链接。

bash 复制代码
wget https://archive.apache.org/dist/rocketmq/5.0.0/rocketmq-all-5.0.0-bin-release.zip  # 请替换为最新版本
unzip rocketmq-all-5.0.0-bin-release.zip
cd rocketmq-all-5.0.0-bin-release

调整 JVM 堆内存参数(重要!) : RocketMQ 默认配置的 JVM 堆内存较大(例如 4GB),如果你的服务器内存资源不充足,务必修改 bin/runserver.shbin/runbroker.sh 中的相关参数,以避免内存不足无法启动。

  • 修改 runserver.sh (NameServer 和 Broker 的启动脚本):
bash 复制代码
# 查找并修改 JAVA_OPT 中的 -Xms, -Xmx, -Xmn 等参数
# 例如,设置为 256m:
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m"

修改 runbroker.sh (Broker 的启动脚本):

bash 复制代码
# 同样修改 JVM 堆内存参数,例如:
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m"

配置 Broker : 编辑 conf/broker.conf 文件,根据你的网络环境进行关键配置:

bash 复制代码
# 设置 NameServer 的地址,如果有多个用分号分隔
namesrvAddr=localhost:9876
# 设置 Broker 对外服务的 IP 地址。如果客户端不在本机,需设置为服务器公网 IP 或内网 IP
brokerIP1=你的服务器IP
# 允许自动创建 Topic(通常建议开发环境开启,生产环境谨慎使用)
autoCreateTopicEnable=true

启动 NameServer 和 Broker

启动 NameServer

bash 复制代码
# 先创建logs/namesrv.log,然后授权chmod 777 logs/namesrv.log,然后在启动mqnamesrv
nohup sh bin/mqnamesrv >> logs/namesrv.log 2>&1 &
tail -f logs/namesrv.log  # 查看日志,确认 "The Name Server boot success"

启动 Broker(指定配置文件):

bash 复制代码
# 先创建logs/broker.log,然后授权chmod 777 logs/broker.log,然后在启动mqbroker
nohup sh bin/mqbroker -n localhost:9876 -c conf/broker.conf >> logs/broker.log 2>&1 &
tail -f logs/broker.log  # 查看日志,确认 "The broker[...] boot success"

注意 :如果 Broker 无法连接到 NameServer 或客户端无法连接 Broker,请务必检查 broker.conf 中的 brokerIP1 和防火墙设置

测试消息发送与消费: RocketMQ 提供了简单的测试工具。

bash 复制代码
# 设置 NameServer 地址环境变量
export NAMESRV_ADDR=localhost:9876
​
# 测试消息发送
sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer
# 你应该能看到发送成功的日志
​
# 测试消息消费
sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer
# 你应该能看到消费到的消息

停止服务

bash 复制代码
sh bin/mqshutdown broker
sh bin/mqshutdown namesrv
相关推荐
阿昌喜欢吃黄桃7 天前
RocketMq事务消息原理
java·中间件·消息队列·rocketmq·mq
huisheng_qaq10 天前
【项目篇-01】Vmware虚拟机和环境安装配置
redis·mysql·canal·rocketmq·es·vaware虚拟机
码农飞哥11 天前
RocketMQ消费接口设计实战:为什么HTTP回调接口必须吞掉所有异常,始终返回成功?
网络协议·http·中间件·消息队列·rocketmq
阿维的博客日记11 天前
细说RocketMQ双网卡问题
rocketmq
北城以北888811 天前
RocketMQ简介
java·spring boot·后端·rocketmq
IT界的老黄牛12 天前
RocketMQ 4.x 任意秒数延迟消息工程实战:MQ 粗延迟 + Redis 补精度 + MDC 链路透传
redis·rocketmq·事务消息·延迟消息
至此流年莫相忘12 天前
Windows 环境下 RocketMQ 安装与 NSSM 后台服务化部署指南
windows·rocketmq
折哥的程序人生 · 物流技术专研13 天前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘
景川呀13 天前
RocketMq知识点
java·rocketmq·java-rocketmq
cfm_291415 天前
RocketMQ源码深度解析(三)消息持久化机制
rocketmq