服务器部署RocketMQ----Docker方式

拉取镜像并创建docker network

按照官方文档提供的方式拉取镜像:docker pull apache/rocketmq:4.9.6

创建一个docker网络:docker network create rocketmq

启动NameServer以及Broker

启动NameServer

bash 复制代码
# 启动NameServer
docker run -d --name rmqnamesrv -p 9876:9876 --net rocketmq apache/rocketmq:4.9.6 sh mqnamesrv
# 验证NameServer是否启动成功
docker logs -f rmqnamesrv
# 启动完成后 查看rmqnamesrv在网络中的ip
docker inspect rmqnamesrv | grep "IPAddress"

如上图所示,我这里的ip是172.23.0.2

启动Broker

bash 复制代码
# 创建broker.conf文件
cat <<EOF > broker.conf
brokerClusterName=DefaultCluster
brokerName=broker-a
brokerId=0
brokerIP1=这里替换为服务器的外网地址
namesrvAddr=这里替换为上一步的ip地址:9876
EOF
# 启动rocketmq broker
docker run -d \
--name rmqbroker \
--net rocketmq \
-p 10912:10912 -p 10911:10911 -p 10909:10909 \
-v ./broker.conf:/home/rocketmq/rocketmq-4.9.6/conf/broker.conf \
apache/rocketmq:4.9.6 sh mqbroker \
-c /home/rocketmq/rocketmq-4.9.6/conf/broker.conf
# 查看日志
docker logs rmqbroker

当日志出现以下语句时,即启动成功

The broker XXX boot success. serializeType=JSON and name server is 172.23.0.2:9876

安装RocketMQ Dashboard可视化面板

bash 复制代码
# 拉取镜像
docker pull apacherocketmq/rocketmq-dashboard:latest
# 运行
docker run -d --name rocketmq-dashboard --net rocketmq -e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.23.0.2:9876" -p 8080:8080 -t apacherocketmq/rocketmq-dashboard:latest
# 查看
docker ps | grep rocketmq-dashboard

最后,记得在云服务器的防火墙中开放以下端口。

默认端口配置下,需开放端口号:控制台:8080;namesrv:9876;broker:10909、10911

相关推荐
j_xxx404_1 小时前
Linux:静态链接与动态链接深度解析
linux·运维·服务器·c++·人工智能
墨风如雪2 小时前
别被“高价建站”劝退了!我跑了多年的 WordPress 架构,一年只花 $25.7
服务器
云飞云共享云桌面3 小时前
东莞智能装备工厂数字化实践—研发部门10名SolidWorks设计共享一台云主机流畅设计
服务器·自动化·汽车·负载均衡·制造
专注API从业者3 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
xingyuzhisuan3 小时前
稳定性考验:连续跑7天,哪家云主机不重启、不掉线?
服务器·人工智能·gpu算力
jsons13 小时前
给每台虚拟机设置独立控制台密码
linux·运维·服务器
皮皮冰燃4 小时前
docker-18-WSL中安装docker并部署flask服务
docker·容器·flask
少年白char4 小时前
整理上万首音乐后的完整工作流:下载、刮削、播放与避坑指南
docker·nas·musictag·音乐刮削·音乐标签
云栖梦泽5 小时前
Linux内核与驱动:14.SPI子系统
linux·运维·服务器·c++
yipiantian5 小时前
在Claude项目中实现跨目录访问Skills
linux·运维·服务器