• 在window和Linux上使用docker安装RocketMQ


    1.创建namesrv服务

    拉取镜像

    1. docker pull rocketmqinc/rocketmq:latest

    启动 namesrv

    1. docker run -d -p 9876:9876 -v D:/programCoding/Docker/rocketmq/namesrv/logs:/root/logs -v D:/programCoding/Docker/rocketmq/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq sh mqnamesrv

    同时会在D盘对应的位置创建二个文件 

    1,定位为注册中心,保存broker节点库路由信息
    2,支持集群模式,每个 namesrv 之间不进行任何通信,多点容灾通过 producer/consumer 再访问 namesrv 时候轮询获取信息(当前节点访问失败就转向下一个)。
    3,namesrv 作为注册中心,负责接收 broker 定期注册信息并维持再内存中,所有数据都保存在内存中,broker 定期的注册过程的也是遍历所有 namesrv 进行注册;
    4,namesrv 提供对外接口对 producer 和 consumer 访问 broker 路由信息,底层用 netty 来实现。
    5,namesrv 对 broker 存活检测采用心跳机制,即 namesrv 作为 broker 的 server 端定期接收 broker 的心跳信息,超时无心跳就移出 broker ,底层通过 epoll 的消息机制来检测连接是否稳定。

    2.创建broker节点

    1. docker run -d -p 10911:10911 -p 10909:10909 -v D:/programCoding/Docker/rocketmq/bocker/logs:/root/logs -v D:/programCoding/Docker/rocketmq/bocker/store:/root/store -v D:/programCoding/Docker/rocketmq/conf/broker.conf:/opt/rocketmq/conf/broker.conf --name rmqbroker --link rmqnamesrv:namesrv -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq sh mqbroker -c /opt/rocketmq/conf/broker.conf

    也会在D盘对应位置创建二个文件 

    启动bocker前需要修改下 bocker.conf 配置文件, 本人的bocker.conf 的安装路径为 D:/programCoding/Docker/rocketmq/conf

    文件内容

    1. brokerClusterName = DefaultCluster // 消费模式,默认集群
    2. brokerName = broker-a
    3. brokerId = 0
    4. deleteWhen = 04// 清除未被消费消息时间,凌晨四点
    5. fileReservedTime = 48 // 消息保留时间
    6. brokerRole = ASYNC_MASTER // broker角色,默认为异步MASTER
    7. flushDiskType = ASYNC_FLUSH // 刷盘策略,异步刷盘
    8. brokerIP1 = 192.168.8.128 //Linux下填Linux公网Ip,Windows利用 docker inspect [imageId],查看IPAddress

    3.创建rockermq-console服务

    拉取镜像

    docker pull styletang/rocketmq-console-ng
    

    构建rockermq-console容器

    需要把192.168.52.136换成部署namesrv机器地址

    docker run -d -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=172.29.80.1:9876 -Drocketmq.config.isVIPChannel=false" -p  9999:8080 -t --name rmConsole styletang/rocketmq-console-ng
    

     (特别注意:这个容器内的端口不能变,必须是8080,挂载的主机端口可以修改)

    ip:9999 访问出现如下界面:

    6、可能遇到的问题

    1.画面可以正常启动,不过从控制台的监控日志上看,存在如下的错误日志。

    org.apache.rocketmq.remoting.exception.RemotingTimeoutException: wait response on the channel <192.168.1.80:10918> timeout, 5000(ms)

    原因是isVIPChannel默认为true,会监控rocketmq的vip通道,将该属性设置为false即可。

    设置后的配置文件如下所示:

    1. server.contextPath=
    2. server.port=8080
    3. #spring.application.index=true
    4. spring.application.name=rocketmq-console
    5. spring.http.encoding.charset=UTF-8
    6. spring.http.encoding.enabled=true
    7. spring.http.encoding.force=true
    8. logging.config=classpath:logback.xml
    9. #if this value is empty,use env value rocketmq.config.namesrvAddr NAMESRV_ADDR | now, you can set it in ops page.default localhost:9876
    10. rocketmq.config.namesrvAddr=192.168.1.80:9876;192.168.1.81:9876
    11. #if you use rocketmq version < 3.5.8, rocketmq.config.isVIPChannel should be false.default true
    12. rocketmq.config.isVIPChannel=false
    13. #rocketmq-console's data path:dashboard/monitor
    14. rocketmq.config.dataPath=/home/hadmin/data/rocketmq
    15. #set it false if you don't want use dashboard.default true
    16. rocketmq.config.enableDashBoardCollect=true

    2.异常信息如下
    org.apache.rocketmq.remoting.exception.RemotingConnectException: connect to failed

    需要关闭防火墙或者开放namesrv和broker端口

    关闭防火墙

    systemctl stop firewalld.service
    

    开放指定端口

    1. firewall-cmd --permanent --zone=public --add-port=9876/tcp
    2. firewall-cmd --permanent --zone=public --add-port=10911/tcp
    3. # 立即生效
    4. firewall-cmd --reload

  • 相关阅读:
    # 案例:验证 app 自动化测试环境是否 OK(测试对象:夜神模拟器以及真机)
    Tomcat架构详解
    搞脑筋的日历积木
    驱动制造业产业升级新思路的领域知识网络,什么来头?
    【网络安全】黑客自学笔记
    2023-2028年中国高纯氟化铵市场深度分析及发展规模预测报告
    HyperLynx(十三)Hyperlynx前放置之对网络的EMC分析
    计算机毕业设计Python+djang高校教室管理系统(源码+系统+mysql数据库+Lw文档)
    分享68个ASP.NET源码总有一个是你想要的
    java多线程使用详解与案例,超详细
  • 原文地址:https://blog.csdn.net/qq_48964306/article/details/127846179