Docker 部署 RocketMQ

0. 拉取镜像

shell 复制代码
docker pull apache/rocketmq:5.2.0
docker pull styletang/rocketmq-console-ng

1. 创建容器共享网络

shell 复制代码
docker network create rocketmq

2. 启动NameServer

shell 复制代码
# 启动 NameServer
docker run -d --name rmqnamesrv -p 9876:9876 --network rocketmq apache/rocketmq:5.2.0 sh mqnamesrv

# 验证 NameServer 是否启动成功
docker logs -f rmqnamesrv

我们可以看到 'The Name Server boot success...', 表示NameServer 已成功启动。

3. 启动 Broker+Proxy

shell 复制代码
# 配置 Broker 的IP地址
[root@localhost rocketmq]# cat broker.conf 
brokerClusterName=DefaultCluster
brokerName=broker-a
brokerId=0
deleteWhen=04
fileReservedTime=48
brokerRole=ASYNC_MASTER
flushDiskType=ASYNC_FLUSH


# 启动 Broker 和 Proxy
docker run -d \
--name rmqbroker \
--network rocketmq \
-p 10912:10912 -p 10911:10911 -p 10909:10909 \
-p 8080:8080 -p 8081:8081 \
-e "NAMESRV_ADDR=rmqnamesrv:9876" \
-v ./broker.conf:/home/rocketmq/rocketmq-5.2.0/conf/broker.conf \
apache/rocketmq:5.2.0 sh mqbroker --enable-proxy \
-c /home/rocketmq/rocketmq-5.2.0/conf/broker.conf

# 验证 Broker 是否启动成功
docker exec -it rmqbroker bash -c "tail -n 10 /home/rocketmq/logs/rocketmqlogs/proxy.log"

我们可以看到 'The broker boot success...', 表示 Broker 已成功启动。

4. rocketmq-console可视化界面

shell 复制代码
[root@localhost rocketmq]# docker run -d \
> --name rmqdashboard \
> --network rocketmq \
> -p 9999:8080 \
> -e "JAVA_OPTS=-Drocketmq.namesrv.addr=rmqnamesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \
> styletang/rocketmq-console-ng

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

shell 复制代码
[root@localhost rocketmq]# docker images
REPOSITORY                      TAG           IMAGE ID       CREATED        SIZE
apache/rocketmq                 5.2.0         07de70081c45   3 months ago   755MB
styletang/rocketmq-console-ng   latest        7df83bb6e638   6 years ago    702MB

[root@localhost rocketmq]# docker ps
CONTAINER ID   IMAGE                           COMMAND                   CREATED          STATUS          PORTS                                                                                                                                                                                           NAMES
77532423d419   styletang/rocketmq-console-ng   "sh -c 'java $JAVA_O..."   27 minutes ago   Up 27 minutes   0.0.0.0:9999->8080/tcp, :::9999->8080/tcp                                                                                                                                                       rmqdashboard
433943f15252   apache/rocketmq:5.2.0           "./docker-entrypoint..."   49 minutes ago   Up 17 minutes   0.0.0.0:8080-8081->8080-8081/tcp, :::8080-8081->8080-8081/tcp, 0.0.0.0:10909->10909/tcp, :::10909->10909/tcp, 0.0.0.0:10911-10912->10911-10912/tcp, :::10911-10912->10911-10912/tcp, 9876/tcp   rmqbroker
ae6cf4adad4a   apache/rocketmq:5.2.0           "./docker-entrypoint..."   54 minutes ago   Up 54 minutes   10909/tcp, 0.0.0.0:9876->9876/tcp, :::9876->9876/tcp, 10911-10912/tcp                                                                                                                           rmqnamesrv
相关推荐
一水鉴天1 天前
整体设计 逻辑系统程序 之18 Source 容器(Docker)承载 C/P/D 三式的完整设计与双闭环验证 之2
docker·架构·认知科学·公共逻辑
飞快的蜗牛1 天前
利用linux系统自带的cron 定时备份数据库,不需要写代码了
java·docker
火星MARK1 天前
k8s面试题
容器·面试·kubernetes
香吧香1 天前
Docker Registry 使用总结
docker
赵渝强老师1 天前
【赵渝强老师】Docker容器的资源管理机制
linux·docker·容器·kubernetes
haicome1 天前
deepseek部署
docker·ragflow·deepseek 部署
乄bluefox1 天前
保姆级docker部署nacos集群
java·docker·容器
每天进步一点_JL1 天前
Docker 是什么?
后端·docker·容器
一叶飘零_sweeeet1 天前
从 0 到 1 掌控云原生部署:Java 项目的 Docker 容器化与 K8s 集群实战指南
docker·云原生·kubernetes·项目部署
森林猿1 天前
docker-compose-kafka 4.1.0
docker·容器·kafka