CentOS下安装RocketMQ

1、安装jdk8

复制代码
sudo yum install java-1.8.0-openjdk

2、下载RocketMQ 4.9.4

bash 复制代码
# 创建安装目录
sudo mkdir -p /usr/local/rocketmq
sudo chown $(whoami):$(whoami) /usr/local/rocketmq
cd /usr/local/rocketmq

# 下载 RocketMQ 4.9.4
wget https://archive.apache.org/dist/rocketmq/4.9.4/rocketmq-all-4.9.4-bin-release.zip

# 如果下载慢,可以使用国内镜像
# wget https://mirrors.tuna.tsinghua.edu.cn/apache/rocketmq/4.9.4/rocketmq-all-4.9.4-bin-release.zip

# 解压
unzip rocketmq-all-4.9.4-bin-release.zip
cd rocketmq-all-4.9.4-bin-release

3、配置修改

ini 复制代码
# 修改NameServer内存配置
cd bin
vim runserver.sh

# 修改JVM参数(大约在20行左右)
# 将: JAVA_OPT="${JAVA_OPT} -server -Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
# 改为(根据你的内存调整,测试环境可以设置小些):
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx512m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m"

# 修改Broker内存配置
vim runbroker.sh

# 修改JVM参数(大约在20行左右)
# 将: JAVA_OPT="${JAVA_OPT} -server -Xms8g -Xmx8g -Xmn4g"
# 改为:
JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx1g -Xmn256m"

# 修改broker配置文件
cd ../conf
vim broker.conf

# 添加或修改以下配置
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
# 添加namesrv地址
namesrvAddr = 127.0.0.1:9876

4、启动RocketMQ

bash 复制代码
# 进入bin目录
cd /home/supdev/rocketmq/rocketmq-all-4.9.4-bin-release/bin

# 在当前会话设置环境变量
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk
export PATH=$JAVA_HOME/bin:$PATH

# 启动NameServer(后台运行)
nohup sh mqnamesrv > /dev/null 2>&1 &

# 查看NameServer日志确认启动成功
tail -f ~/logs/rocketmqlogs/namesrv.log
# 看到"The Name Server boot success."表示启动成功

# 启动Broker
nohup sh mqbroker -n localhost:9876 -c ../conf/broker.conf > /dev/null 2>&1 &

# 查看Broker日志
tail -f ~/logs/rocketmqlogs/broker.log
# 看到"The broker[...] boot success."表示启动成功

5、设置开机自启

ini 复制代码
# 创建systemd服务文件
sudo tee /etc/systemd/system/rocketmq-namesrv.service << 'EOF'
[Unit]
Description=RocketMQ NameServer
After=network.target

[Service]
Type=forking
User=$(whoami)
WorkingDirectory=/usr/local/rocketmq/rocketmq-all-4.9.4-bin-release/bin
ExecStart=/usr/local/rocketmq/rocketmq-all-4.9.4-bin-release/bin/mqnamesrv
ExecStop=/usr/bin/pkill -f namesrv
Restart=always
RestartSec=10

[Install]
WantedBy=multi-user.target
EOF

sudo tee /etc/systemd/system/rocketmq-broker.service << 'EOF'
[Unit]
Description=RocketMQ Broker
After=network.target rocketmq-namesrv.service

[Service]
Type=forking
User=$(whoami)
WorkingDirectory=/usr/local/rocketmq/rocketmq-all-4.9.4-bin-release/bin
ExecStart=/usr/local/rocketmq/rocketmq-all-4.9.4-bin-release/bin/mqbroker -n localhost:9876 -c ../conf/broker.conf
ExecStop=/usr/bin/pkill -f broker
Restart=always
RestartSec=10

[Install]
WantedBy=multi-user.target
EOF

# 重新加载systemd
sudo systemctl daemon-reload

# 设置开机启动
sudo systemctl enable rocketmq-namesrv
sudo systemctl enable rocketmq-broker

6、测试安装

bash 复制代码
# 验证服务状态
jps | grep -E "NamesrvStartup|BrokerStartup"

# 发送测试消息
export NAMESRV_ADDR=localhost:9876

# 生产消息
sh tools.sh org.apache.rocketmq.example.quickstart.Producer

# 消费消息(新开终端)
cd /usr/local/rocketmq/rocketmq-all-4.9.4-bin-release/bin
export NAMESRV_ADDR=localhost:9876
sh tools.sh org.apache.rocketmq.example.quickstart.Consumer

7、dashboard安装

bash 复制代码
cd /usr/local/rocketmq

# 下载预编译的 dashboard
wget https://github.com/apache/rocketmq-dashboard/releases/download/rocketmq-dashboard-1.0.0/rocketmq-dashboard-1.0.0.jar

# 或者从 Maven 中央仓库下载
wget https://repo1.maven.org/maven2/org/apache/rocketmq/rocketmq-dashboard/1.0.0/rocketmq-dashboard-1.0.0.jar

cd /usr/local/rocketmq

# 创建配置文件目录
mkdir -p /usr/local/rocketmq/dashboard-config

# 创建配置文件
cat > /usr/local/rocketmq/dashboard-config/application.properties << 'EOF'
# Nameserver 地址(根据您的实际配置修改)
rocketmq.config.namesrvAddr=localhost:9876

# 服务端口
server.port=8080

# 是否开启登录验证(false表示不需要登录)
rocketmq.config.loginRequired=false

# 其他可选配置
rocketmq.config.dataPath=/tmp/rocketmq-dashboard
logging.level.com.alibaba.rocketmq=INFO
EOF

#启动
cd /usr/local/rocketmq
nohup java -jar rocketmq-dashboard-1.0.0.jar --spring.config.location=dashboard-config/application.properties > dashboard.log 2>&1 &
相关推荐
Cache技术分享7 小时前
273. Java Stream API - Stream 中的中间操作:Mapping 操作详解
前端·后端
天天摸鱼的java工程师7 小时前
Docker+K8s 部署微服务:从搭建到运维的全流程指南(Java 老鸟实战版)
java·后端
Undoom7 小时前
Redis 数据库的服务器部署与 MCP 智能化交互深度实践指南
后端
法欧特斯卡雷特7 小时前
如何解决 Kotlin/Native 在 Windows 下 main 函数的 args 乱码?
后端·操作系统·编程语言
南囝coding7 小时前
《独立开发者精选工具》第 024 期
前端·后端
古城小栈7 小时前
性能边界:何时用 Go 何时用 Java 的技术选型指南
java·后端·golang
qq_172805597 小时前
Modbus Server数据采集Web之Server端模拟功能
前端·后端·golang·modbus
算法与双吉汉堡8 小时前
【短链接项目笔记】Day1 用户模块
java·spring boot·笔记·后端