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
相关推荐
hjxu20165 小时前
【OpenClaw 龙虾养成笔记一】在远程服务器,使用Docker安装OpenClaw
服务器·笔记·docker
Stewie121387 小时前
Docker 面试题
运维·docker·容器
vpk1128 小时前
Docker Compose 安装 Redis
redis·docker·容器
last demo10 小时前
Docker-compose和图形界面管理
docker·容器·eureka
好像不对劲11 小时前
【docker】win10 wsl docker不能挂GPU
运维·docker·容器·wsl
江畔何人初12 小时前
Docker、containerd、CRI、shim 之间的关系
运维·docker·云原生·容器·kubernetes
杨浦老苏13 小时前
在线视频播放器YT-DLP Web Player
docker·工具·群晖·下载·多媒体
ALex_zry13 小时前
Docker Compose 配置文件完全指南:从基础到生产级安全实践
服务器·安全·docker
万象.14 小时前
docker镜像仓库
运维·docker·容器
姚不倒14 小时前
Docker 核心原理与运维实战:从入门到生产级理解
运维·docker·架构