我的编程空间,编程开发者的网络收藏夹
学习永远不晚

docker安装rocketMQ和安装过程中出现问题的解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

docker安装rocketMQ和安装过程中出现问题的解决

本文主要介绍安装rocketMQ4.4.0,主要分为四步,分别为:
1、拉取rocketmq镜像。
2、创建namesrv。
3、创建broker节点,我在这里介绍的是创建单个broker的。
4、rocketMQ-console服务,用于管理rocketMQ的管理界面。

拉取rocketmq镜像

docker命令如下


docker pull rocketmqinc/rocketmq:4.4.0

创建namesrv

docker命令


docker run -d --name rmqnamesrv -p 9876:9876 -v C:\data\rocketmq\logs:/root/logs -v C:\data\rocketmq\store:/root/store -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq:4.4.0 sh mqnamesrv

参数解释

参数 描述
-d 以守护进程的方式启动
- -name 设置容器的名字
-p 容器9876端口映射到本机9876端口上
-v 把容器/root/logs(日志文件)目录映射到本机对应路径上 /把容器/root/store(数据存储)目录映射到本机对应路径上
-e 设置容器最大堆内存为 100000000
rocketmqinc/rocketmq:4.4.0 镜像名称:版本
sh 启动服务mqnamesrv

创建单个broker节点

docker命令

docker run -d --name rmqbroker --link rmqnamesrv:namesrv -p 10911:10911 -p 10909:10909 --privileged=true -v  C:\data\broker\logs:/root/logs -v  C:\data\broker\store:/root/store -v C:\data\broker\conf\broker.conf:/opt/rocketmq-4.4.0/conf/broker.conf -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq:4.4.0 sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf

参数解释

参数 描述
-d 以守护进程的方式启动
- -name 设置容器的名字
- -link 和rmqnamesrv 容器建立通讯
-p 10911:10911 把容器的非VIP通讯端口10911映射到本机10911端口
-p 10909:10909 把容器的VIP通讯端口1090映射到本机10909端口
–privileged=true 设置允许挂载私有文件夹
-v 把容器/root/logs(日志文件)目录映射到本机对应路径上 /把容器/root/store(数据存储)目录映射到本机对应路径上 / 把容器/opt/rocketmq-4.4.0/conf/broker.conf配置文件映射到本机对应路径上(每次可以修改本机上的broker.conf文件,重启容器即可)
-e “NAMESRV_ADDR=namesrv:9876” 指定namesrv的地址为本机的9876
-e “MAX_POSSIBLE_HEAP=200000000” 设置broker服务的最大堆内存为 200000000
rocketmqinc/rocketmq:4.4.0 镜像名称:版本
sh mqbroker 启动服务mqbroker
-c /opt/rocketmq-4.4.0/conf/broker.conf 指定配置文件启动broker

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 = ASYNC_MASTER
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH
# 设置broker节点所在服务器的ip地址
namesrvAddr = 本机ip地址:9876
brokerIP1 = 本机ip地址

broker.conf配置文件中如果不加namesrvAddr配置,运行程序时会报如下的错:

Exception in thread "main" org.apache.rocketmq.remoting.exception.RemotingTooMuchRequestException: sendDefaultImpl call timeout
 at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.sendDefaultImpl(DefaultMQProducerImpl.java:588)
 at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1223)
 at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1173)
 at org.apache.rocketmq.client.producer.DefaultMQProducer.send(DefaultMQProducer.java:214)
 at com.baojian.mob.base.producer.SyncProducer.main(SyncProducer.java:41)
15:22:31.455 [NettyClientSelector_1] INFO RocketmqRemoting - closeChannel: close the connection to remote address[] result: true
15:22:32.049 [NettyClientSelector_1] INFO RocketmqRemoting - closeChannel: close the connection to remote address[] result: true

rocketMQ-console服务

docker命令

可以不使用docker pull 命令进行镜像拉取,直接执行docker run命令,如果此镜像不存在会先拉取镜像在执行docker run。


docker run -d --name rmqadmin -e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.16.122.115:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8081:8080 pangliang/rocketmq-console-ng

参数说明

描述 说明
-d 以守护进程的方式启动
- -name 设置容器的名字
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.16.122.115:9876 设置namesrv服务的IP地址
-Dcom.rocketmq.sendMessageWithVIPChannel=false" 不使用VIP通道发送消息
-p 8081:8080 把容器内的端口8080映射到主机上的8081端口

rocketmq-console界面
容器运行成功后,使用浏览器打开 http://127.0.0.1:8081 就可以进入到rokcetmq-console管理界面,看到集群信息,说明rocketmq安装成功了。

在这里插入图片描述

rocketmq-console生产者界面报错问题

在这里插入图片描述

点击搜索报错,是因为生产者创建生产组后使用producer.shutdown()将它关闭了,将下面代码注销即可。

在这里插入图片描述

到此这篇关于docker安装rocketMQ和安装过程中出现问题的解决的文章就介绍到这了,更多相关docker安装rocketMQ内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

docker安装rocketMQ和安装过程中出现问题的解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

docker安装rocketMQ和安装过程中出现问题怎么处理

小编给大家分享一下docker安装rocketMQ和安装过程中出现问题怎么处理,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!本文主要介绍安装rocketMQ4.4.0,主要分为四步,分别为:1、拉取rocketmq镜像。2
2023-06-22

安装Win8.1过程中出现的各种问题解决技巧

大家在安装Windows 8.1的过程中,是不是出现过很多问题呢?在这里,小编给大家分享一个教程,洗完能对大家有所帮助。ps:机子是6G内存、500G硬盘,原装系统是Windows 7,想换成Windows 8.1,下载了64位的Windo
2022-06-04

安装Windows 8.1过程中出现的各种问题怎么解决?安装Windows 8.1教程

这个周末就安装了个系统,本以为一个小时就能搞定,没想到花费了将近一天。 我的机子是6G内存、500G硬盘,原装系统是Windows 7,现在想换成Windows 8.1,于是下载了64位的Windows 8.1 ISO镜像文件,用Daemo
2022-06-04

Centos7.4服务器安装apache及安装过程出现的问题解决方法

本文实例讲述了Centos7.4服务器安装apache及安装过程出现的问题解决方法。分享给大家供大家参考,具体如下: 一、安装httpd 1. 安装之前,先查看系统中是否存在已经安装了的httpd.rpm包,如果,没有就是没安装,有的话rp
2022-06-04

解决安装tomcat时出现的问题

解决安装Tomcat问题:解决端口冲突、Java版本不匹配、环境变量未配置、权限问题、防火墙阻止、缺少依赖项、错误安装目录等问题,方法包括更改端口号、安装兼容Java版本、设置环境变量、授予权限、将Tomcat添加到防火墙例外、安装依赖项和更正安装目录。
解决安装tomcat时出现的问题
2024-04-02

Docker安装MySql遇到的问题解决

本指南提供了在Docker容器中安装MySQL时解决常见问题的步骤:无法连接到容器:检查守护程序、网络设置、防火墙和容器状态。MySQL容器崩溃:检查日志、资源限制、配置、磁盘空间和系统资源。数据丢失:使用持久卷、启用持久性或遵循官方机制。权限问题:检查用户权限、组设置和外部访问权限。缺少扩展:在Dockerfile中安装扩展、确保依赖项和加载配置。性能问题:优化MySQL配置、提高网络连接速度和考虑使用卷。其他常见问题:检查InnoDB引擎、数据库权限、网络问题、服务启动和参数有效性。
Docker安装MySql遇到的问题解决
2024-04-02

安装Win8.1过程中出现的各种问题如何解决?制作U盘启动盘安装Win8.1

机子是6G内存、500G硬盘,原装系统是Windows 7,现在想换成Windows 8.1,于是下载了64位的Windows 8.1 ISO镜像文件,用DaemonTools打开,打开后如果直接点击setup.exe那么只会在你现在的系统
2022-06-04

如何解决InternetExplorer9安装时出现的问题

要解决Internet Explorer 9安装时出现的问题,可以尝试以下方法:1. 检查系统要求:确保你的计算机符合Internet Explorer 9的系统要求。例如,你的操作系统是否为Windows 7或更高版本。2. 关闭防火墙和
2023-09-07

docker容器中安装vim问题怎么解决

这篇文章主要介绍“docker容器中安装vim问题怎么解决”,在日常操作中,相信很多人在docker容器中安装vim问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”docker容器中安装vim问题怎
2023-06-20

编程热搜

目录