【RocketMQ、Docker】Docker 安装 RocketMQ-4.9.3

一、Name Server搭建

1、创建挂载的目录
在这里插入图片描述
2、通过Docker Hub获取最新镜像,本文使用4.9.3版本。Docker:apache/rocketmq

docker pull apache/rocketmq:4.9.3

3、创建一个新的网络连接

docker network create rocketmq

4、创建容器

docker run -d --name rocketmq-namesrv --network rocketmq -p 9876:9876 -v /home/docker/mount/rocketmq/namesrv/logs:/root/logs -v /home/docker/mount/rocketmq/namesrv/store:/root/store apache/rocketmq:4.9.3 sh mqnamesrv

5、创建成功
在这里插入图片描述

二、Broker搭建

1、创建挂载的目录
在这里插入图片描述
2、使用Docker命令复制Name Server服务中得Broker配置。
docker cp 容器ID:容器内文件位置 本地位置

docker cp 55a0480ec59d:/home/rocketmq/rocketmq-4.9.3/conf /home/docker/mount/rocketmq/broker/broker-a/

3、修改conf中的broker.conf文件

# 所属集群名称,如果节点较多可以配置多个
brokerClusterName = DefaultCluster
#broker名称,master和slave使用相同的名称,表明他们的主从关系
brokerName = broker-a
#0表示Master,大于0表示不同的slave
brokerId = 0
#表示几点做消息删除动作,默认是凌晨4点
deleteWhen = 04
#在磁盘上保留消息的时长,单位是小时
fileReservedTime = 48
#有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机制;
brokerRole = SYNC_MASTER
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = SYNC_FLUSH
# 设置broker节点所在服务器的ip地址(**这个非常重要,主从模式下,从节点会根据主节点的brokerIP2来同步数据,如果不配置,主从无法同步,brokerIP1设置为自己外网能访问的ip,服务器双网卡情况下必须配置,比如阿里云这种,主节点需要配置ip1和ip2,从节点只需要配置ip1即可)
brokerIP1 = 10.101.68.203
#nameServer地址,分号分割
namesrvAddr=10.101.68.203:9876
#Broker 对外服务的监听端口,
listenPort = 10911
#是否允许Broker自动创建Topic
autoCreateTopicEnable = true
#是否允许 Broker 自动创建订阅组
autoCreateSubscriptionGroup = true
#linux开启epoll
useEpollNativeSelector = true

#数据存放的根目录
#storePathRootDir = /root/store/path
#commit log保存目录
#storePathCommitLog = /root/store/path/commitlog
#消费队列存储路径存储路径
#storePathConsumerQueue = /root/store/path/consumequeue

slaveReadEnable = true

rocketmq默认配置和解释(详细版)
4、创建容器
默认内存大小

docker run -d --name rocketmq-broker-a --network rocketmq -p 10909:10909 -p 10911:10911 -v /home/docker/mount/rocketmq/broker/broker-a/logs:/root/logs -v /home/docker/mount/rocketmq/broker/broker-a/store:/root/store -v /home/docker/mount/rocketmq/broker/broker-a/conf:/home/rocketmq/rocketmq-4.9.3/conf apache/rocketmq:4.9.3 sh mqbroker -c /home/rocketmq/rocketmq-4.9.3/conf/broker.conf

指定内存大小

docker run -d --name rocketmq-broker-a --network rocketmq -p 10909:10909 -p 10911:10911 -v /home/docker/mount/rocketmq/broker/broker-a/logs:/root/logs -v /home/docker/mount/rocketmq/broker/broker-a/store:/root/store -v /home/docker/mount/rocketmq/broker/broker-a/conf:/home/rocketmq/rocketmq-4.9.3/conf -e "JAVA_OPT_EXT=-server -Xms1g -Xmx1g -Xmn512m" apache/rocketmq:4.9.3 sh mqbroker -c /home/rocketmq/rocketmq-4.9.3/conf/broker.conf

5、创建成功
在这里插入图片描述

三、console控制台搭建

1、创建容器

docker run -d --name rocketmq-console --network rocketmq -e "JAVA_OPTS=-Drocketmq.namesrv.addr=rocketmq-namesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8000:8080 apacherocketmq/rocketmq-dashboard:latest

2、创建成功
在这里插入图片描述
3、打开控制台。http://IP:8000
在这里插入图片描述
4、运维控制台使用详解:RocketMQ系列:rocketmq运维控制台使用详解(全网独家)

### 如何配置 RocketMQ 的 `docker-compose.yml` 文件 为了成功部署并运行 RocketMQ,可以通过定义一个详细的 `docker-compose.yml` 文件来简化这一过程。以下是基于最佳实践的一个实例化方案。 #### 定义服务依赖关系和服务本身 RocketMQ通常由多个组件构成,包括Name Server 和 Broker。因此,在 `docker-compose.yml` 中至少要声明这两个主要的服务实体: ```yaml version: '3' services: namesrv1: image: apacherocketmq/rocketmq:4.9.3 container_name: rocketmq-namesrv1 environment: - TZ=Asia/Shanghai command: "sh mqnamesrv" ports: - "9876:9876" broker1: image: apacherocketmq/rocketmq:4.9.3 container_name: rocketmq-broker1 depends_on: - namesrv1 environment: - NAME_SERVER_ADDR=namesrv1:9876 - BROKER_IP1=localhost - TZ=Asia/Shanghai command: "sh mbroker -n namesrv1:9876" ports: - "10911:10911" - "10909:10909" ``` 此配置文件中指定了两个服务:一个是名为 `namesrv1` 的 NameServer 实例;另一个是名为 `broker1` 的Broker实例[^1]。通过设置环境变量 `NAME_SERVER_ADDR` 来告知Broker连接哪个NameServer节点,并且设置了时区以确保时间戳的一致性[^3]。 #### 设置持久化存储 考虑到消息队列的重要性以及可能产生的大量日志记录,建议为每个容器配置独立的数据卷用于保存必要的状态信息和日志文件。这不仅有助于提高系统的稳定性和可靠性,而且便于后续维护工作中的数据迁移或备份操作。 ```yaml volumes: - ./data/broker/store:/home/rocketmq/store - ./data/broker/logs:/home/rocketmq/logs ``` 上述代码片段展示了如何将本地磁盘上的特定目录映射至容器内的相应位置,从而实现外部化的持久储存解决方案[^4]。 #### 启动命令说明 当使用 `docker-compose up` 命令启动项目时,Compose工具会按照顺序先创建再启动所有的容器。如果有任何更改被应用到了YAML描述文档上,则这些改动将会触发新一轮的构建流程,最终得到更新后的容器实例[^2]。
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值