日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

docker安裝rocketMQ和安裝過程中出現問題的解決_docker

作者:Y呀 ? 更新時間: 2022-03-17 編程語言

本文主要介紹安裝rocketMQ4.4.0,主要分為四步,分別為:
1、拉取rocketmq鏡像。
2、創(chuàng)建namesrv。
3、創(chuàng)建broker節(jié)點,我在這里介紹的是創(chuàng)建單個broker的。
4、rocketMQ-console服務,用于管理rocketMQ的管理界面。

拉取rocketmq鏡像

docker命令如下

docker pull rocketmqinc/rocketmq:4.4.0

創(chuàng)建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

創(chuàng)建單個broker節(jié)點

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文件配置

#如果節(jié)點較多可以配置多個
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消息寫入磁盤后才返回成功狀態(tài),ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH
# 設置broker節(jié)點所在服務器的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 命令進行鏡像拉取,直接執(zhí)行docker run命令,如果此鏡像不存在會先拉取鏡像在執(zhí)行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通道發(fā)送消息
-p 8081:8080 把容器內的端口8080映射到主機上的8081端口

rocketmq-console界面
容器運行成功后,使用瀏覽器打開 http://127.0.0.1:8081 就可以進入到rokcetmq-console管理界面,看到集群信息,說明rocketmq安裝成功了。

在這里插入圖片描述

rocketmq-console生產者界面報錯問題

在這里插入圖片描述

點擊搜索報錯,是因為生產者創(chuàng)建生產組后使用producer.shutdown()將它關閉了,將下面代碼注銷即可。

在這里插入圖片描述

原文鏈接:https://blog.csdn.net/weixin_45003796/article/details/122156567

欄目分類
最近更新