【RocketMQ、Docker】Docker 安装 RocketMQ-4.9.3:总结遇到的问题

本文分析了在尝试挂载目录启动RocketMQ Broker容器时遇到的问题,即由于目录权限导致的启动失败。当挂载的目录由root权限创建,而容器内部默认使用rocketmq用户时,容器无法进行写入操作。解决方案包括修改挂载目录的权限为777,以及在使用docker exec进入容器时指定root用户。文章还提到了在容器内执行命令时因权限不足引发的错误及其解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、容器挂载数据存放的根目录后容器启动不成功。

背景

broker容器启动成功后,默认的数据存在位置在容器内部的/home/rocketmq/store中,当我们挂载该目录后,会导致容器无法启动成功。
使用的命令:

docker run -d --name rocketmq-broker-a --network rocketmq \
-p 10909:10909 -p 10911:10911 -p 10912:10912 \
-v /home/docker/mount/rocketmq/broker/broker-a/logs:/home/rocketmq/logs \
-v /home/docker/mount/rocketmq/broker/broker-a/store:/home/rocketmq/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

分析

通过排查发现,创建挂载的目录是root权限创建得,而容器默认使用的是rocketmq权限。所以无法做写入操作。
在这里插入图片描述
在这里插入图片描述

解决方案:

映射本地目录权限设置为 777 权限。设置之后在创建容器。
参考链接

二、容器内部提示:bash: cd: /root: Permission denied

背景

使用docker exec -it 容器ID /bin/bash命令进入Broker容器、NameServer容器后操作由root权限创建得文件夹时,会提示Permission denied。
在这里插入图片描述

原因

目录是root权限创建得,而容器默认使用的是rocketmq权限,所以提示没有权限。

解决方案:

使用docker exec -it -u root 容器ID /bin/bash命令进入容器。

docker exec -it -u root 容器ID /bin/bash
### 如何配置 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]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值