Docker 部署 RocketMQ

0. 拉取镜像

docker pull apache/rocketmq:5.2.0
docker pull styletang/rocketmq-console-ng

1. 创建容器共享网络

docker network create rocketmq

2. 启动NameServer

# 启动 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

# 配置 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可视化界面

[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

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

[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. docker-compose部署RocketMq

    2024-06-14 06:56:04       29 阅读
  2. Docker 部署 RocketMQ

    2024-06-14 06:56:04       33 阅读
  3. RocketMq安装部署(centos)

    2024-06-14 06:56:04       40 阅读
  4. 使用docker安装RocketMQ

    2024-06-14 06:56:04       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-14 06:56:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-14 06:56:04       101 阅读
  3. 在Django里面运行非项目文件

    2024-06-14 06:56:04       82 阅读
  4. Python语言-面向对象

    2024-06-14 06:56:04       91 阅读

热门阅读

  1. 算法题day43(补5.29日卡:动态规划03)

    2024-06-14 06:56:04       31 阅读
  2. XSLT <for-each> 元素深入解析

    2024-06-14 06:56:04       29 阅读
  3. 前端场景题:实现监控请求时常

    2024-06-14 06:56:04       24 阅读
  4. 在Elasticsearch中-SpaceJam一个全文搜索的实例

    2024-06-14 06:56:04       29 阅读
  5. Linux常用命令

    2024-06-14 06:56:04       34 阅读