Docker部署RocketMQ时Broker IP地址问题及解决方案

Docker部署RocketMQ时Broker IP地址问题及解决方案

问题描述

在最近的一次项目中,为了方便,项目中所用到的第三方服务都使用Docker容器化部署。当部署RocketMQ时,出现了生产者发送消息到队列,但观察控制台却没有接收到消息的情况。

问题现象

在RocketMQ控制台中观察到Broker集群的地址为Docker内部生成的内网IP:

Broker NO. Address Version Produce Message TPS Consumer Message TPS Yesterday Produce Count Yesterday Consume Count Today Produce Count Today Consume Count Operation
049c9d62b8a8 0(master) 172.17.0.6:10911 V4_4_0 0.00 0.00 0 0 0 0

问题原因

使用Docker部署时,Broker默认注册的是Docker容器内部生成的内网IP地址,导致外部生产者无法正确连接到Broker服务。

解决方案

方法一:修改Broker配置文件

  1. 进入Broker容器

    bash 复制代码
    docker exec -it broker /bin/bash
  2. 修改Broker配置文件

    bash

    bash 复制代码
    vi /opt/rocketmq/conf/broker.conf
  3. 添加公网IP配置

    properties

    bash 复制代码
    brokerIP1 = 你的公网地址
  4. 重启Broker服务

    bash 复制代码
    # 在宿主机操作
    docker restart broker

方法二:使用Docker启动参数

bash 复制代码
docker run -d \
  --name broker \
  -p 10911:10911 \
  -p 10909:10909 \
  -e "NAMESRV_ADDR=你的公网IP:9876" \
  -e "BROKER_IP=你的公网IP" \
  -v /docker/rocketmq/broker/conf/broker.conf:/opt/rocketmq/conf/broker.conf \
  rocketmqinc/rocketmq:latest \
  sh mqbroker -n 你的公网IP:9876 -c /opt/rocketmq/conf/broker.conf

验证结果

修改配置并重启Broker后,在RocketMQ控制台中观察到的Broker地址应该变为:

Broker NO. Address Version
049c9d62b8a8 0(master) 你的公网IP:10911 V4_4_0

总结

Docker部署RocketMQ时,由于网络隔离的特性,Broker默认会注册容器内部IP地址。通过显式配置brokerIP1参数,可以强制Broker使用公网IP地址进行注册,从而解决生产者无法连接的问题。

这种方法确保了外部应用程序能够正确发现和连接到RocketMQ Broker服务,保证了消息的正常生产和消费。

相关推荐
噔噔君4 小时前
嵌入式模组拨号获取IP地址时,设置的ippass是什么原理,起到什么作用?
服务器·网络协议·tcp/ip·ip
深蓝电商API5 小时前
爬虫+Docker:让你的爬虫项目一键部署、可移植
爬虫·docker·容器
ehiway5 小时前
国际先进!中科亿海微国产嵌入式FPGA IP核及EDA系统设计技术通过科技成果评价
网络协议·tcp/ip·fpga开发
ZHE|张恒6 小时前
使用 Docker 容器测试端口开放性
运维·docker·容器
“αβ”6 小时前
了解“网络协议”
linux·服务器·网络·c++·网络协议·tcp/ip·tcp
切糕师学AI6 小时前
云原生技术栈解析:宿主机、容器、Docker、Kubernetes 之间的区别于联系
docker·云原生·容器·kubernetes
_dindong7 小时前
Linux网络编程:Socket编程TCP
linux·服务器·网络·笔记·学习·tcp/ip
java_logo8 小时前
Docker 部署 MinIO 全指南
运维·windows·mongodb·docker·容器
我狸才不是赔钱货9 小时前
DevOps:打破开发与运维之间的高墙
运维·vscode·docker·devops