以下内容介绍了如何通过 Docker Compose 快速部署一个单节点、单副本的 RocketMQ 服务,并完成简单的消息发送和接收。Docker Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。通过一个 YAML 文件 (docker-compose.yml
) 来配置应用程序的服务,然后使用一个命令就可以启动所有服务。
分步解析
1. 编写 docker-compose.yml
以下是用于快速启动和运行 RocketMQ 集群的模板:
version: '3.8'
services:
namesrv:
image: apache/rocketmq:5.3.2
container_name: rmqnamesrv
ports:
- 9876:9876
networks:
- rocketmq
command: sh mqnamesrv
broker:
image: apache/rocketmq:5.3.2
container_name: rmqbroker
ports:
- 10909:10909
- 10911:10911
- 10912:10912
environment:
- NAMESRV_ADDR=rmqnamesrv:9876
depends_on:
- namesrv
networks:
- rocketmq
command: sh mqbroker
proxy:
image: apache/rocketmq:5.3.2
container_name: rmqproxy
networks:
- rocketmq
depends_on:
- broker
- namesrv
ports:
- 8080:8080
- 8081:8081
restart: on-failure
environment:
- NAMESRV_ADDR=rmqnamesrv:9876
command: sh mqproxy
networks:
rocketmq:
driver: bridge
- Namesrv:RocketMQ 的名称服务器(Name Server),负责维护主题路由信息。
- Broker:消息队列服务的核心组件,负责存储消息并提供消息收发接口。
- Proxy:作为代理层,提供给客户端接入使用,可以减轻 Broker 直接面对大量客户端的压力。
2. 启动 RocketMQ 集群
执行以下命令来根据 docker-compose.yml
文件启动所有定义的服务:
docker-compose up -d
-d
参数表示在后台运行容器。
3. 停止所有服务
当你完成测试或不再需要运行这些服务时,可以通过下面的命令停止并移除所有由 Docker Compose 管理的容器和服务:
docker-compose down
这将停止所有相关的容器并将它们从当前运行环境中移除,但不会删除已创建的数据卷和网络,除非特别指定。
总结
通过上述步骤,你可以非常方便地搭建一套基于 Docker 的 RocketMQ 环境,非常适合开发测试阶段使用。这种方式简化了手动部署每个组件的过程,并且通过 Docker Compose 可以很容易地管理整个应用生命周期,包括启动、停止和清理环境。这对于想要快速体验 RocketMQ 功能或是进行相关开发工作的开发者来说是非常有帮助的。