docker安裝rocketMQ和安裝過(guò)程中出現(xiàn)問(wèn)題的解決
本文主要介紹安裝rocketMQ4.4.0,主要分為四步,分別為:
1、拉取rocketmq鏡像。
2、創(chuàng)建namesrv。
3、創(chuàng)建broker節(jié)點(diǎn),我在這里介紹的是創(chuàng)建單個(gè)broker的。
4、rocketMQ-console服務(wù),用于管理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
參數(shù)解釋
參數(shù) | 描述 |
---|---|
-d | 以守護(hù)進(jìn)程的方式啟動(dòng) |
- -name | 設(shè)置容器的名字 |
-p | 容器9876端口映射到本機(jī)9876端口上 |
-v | 把容器/root/logs(日志文件)目錄映射到本機(jī)對(duì)應(yīng)路徑上 /把容器/root/store(數(shù)據(jù)存儲(chǔ))目錄映射到本機(jī)對(duì)應(yīng)路徑上 |
-e | 設(shè)置容器最大堆內(nèi)存為 100000000 |
rocketmqinc/rocketmq:4.4.0 | 鏡像名稱:版本 |
sh | 啟動(dòng)服務(wù)mqnamesrv |
創(chuàng)建單個(gè)broker節(jié)點(diǎn)
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
參數(shù)解釋
參數(shù) | 描述 |
---|---|
-d | 以守護(hù)進(jìn)程的方式啟動(dòng) |
- -name | 設(shè)置容器的名字 |
- -link | 和rmqnamesrv 容器建立通訊 |
-p 10911:10911 | 把容器的非VIP通訊端口10911映射到本機(jī)10911端口 |
-p 10909:10909 | 把容器的VIP通訊端口1090映射到本機(jī)10909端口 |
–privileged=true | 設(shè)置允許掛載私有文件夾 |
-v | 把容器/root/logs(日志文件)目錄映射到本機(jī)對(duì)應(yīng)路徑上 /把容器/root/store(數(shù)據(jù)存儲(chǔ))目錄映射到本機(jī)對(duì)應(yīng)路徑上 / 把容器/opt/rocketmq-4.4.0/conf/broker.conf配置文件映射到本機(jī)對(duì)應(yīng)路徑上(每次可以修改本機(jī)上的broker.conf文件,重啟容器即可) |
-e “NAMESRV_ADDR=namesrv:9876” | 指定namesrv的地址為本機(jī)的9876 |
-e “MAX_POSSIBLE_HEAP=200000000” | 設(shè)置broker服務(wù)的最大堆內(nèi)存為 200000000 |
rocketmqinc/rocketmq:4.4.0 | 鏡像名稱:版本 |
sh mqbroker | 啟動(dòng)服務(wù)mqbroker |
-c /opt/rocketmq-4.4.0/conf/broker.conf | 指定配置文件啟動(dòng)broker |
broker.conf文件配置
#如果節(jié)點(diǎn)較多可以配置多個(gè) brokerClusterName = DefaultCluster #broker名稱,master和slave使用相同的名稱,表明他們的主從關(guān)系 brokerName = broker-a #0表示Master,大于0表示不同的slave brokerId = 0 #表示幾點(diǎn)做消息刪除動(dòng)作,默認(rèn)是凌晨4點(diǎn) deleteWhen = 04 #在磁盤上保留消息的時(shí)長(zhǎng),單位是小時(shí) fileReservedTime = 48 #有三個(gè)值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和異步表示Master和Slave之間同步數(shù)據(jù)的機(jī)制; brokerRole = ASYNC_MASTER #刷盤策略,取值為:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盤和異步刷盤;SYNC_FLUSH消息寫入磁盤后才返回成功狀態(tài),ASYNC_FLUSH不需要; flushDiskType = ASYNC_FLUSH # 設(shè)置broker節(jié)點(diǎn)所在服務(wù)器的ip地址 namesrvAddr = 本機(jī)ip地址:9876 brokerIP1 = 本機(jī)ip地址
broker.conf配置文件中如果不加namesrvAddr配置,運(yùn)行程序時(shí)會(huì)報(bào)如下的錯(cuò):
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服務(wù)
docker命令
可以不使用docker pull 命令進(jìn)行鏡像拉取,直接執(zhí)行docker run命令,如果此鏡像不存在會(huì)先拉取鏡像在執(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
參數(shù)說(shuō)明
描述 | 說(shuō)明 |
---|---|
-d | 以守護(hù)進(jìn)程的方式啟動(dòng) |
- -name | 設(shè)置容器的名字 |
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=172.16.122.115:9876 | 設(shè)置namesrv服務(wù)的IP地址 |
-Dcom.rocketmq.sendMessageWithVIPChannel=false" | 不使用VIP通道發(fā)送消息 |
-p 8081:8080 | 把容器內(nèi)的端口8080映射到主機(jī)上的8081端口 |
rocketmq-console界面
容器運(yùn)行成功后,使用瀏覽器打開 http://127.0.0.1:8081 就可以進(jìn)入到rokcetmq-console管理界面,看到集群信息,說(shuō)明rocketmq安裝成功了。
rocketmq-console生產(chǎn)者界面報(bào)錯(cuò)問(wèn)題
點(diǎn)擊搜索報(bào)錯(cuò),是因?yàn)樯a(chǎn)者創(chuàng)建生產(chǎn)組后使用producer.shutdown()將它關(guān)閉了,將下面代碼注銷即可。
到此這篇關(guān)于docker安裝rocketMQ和安裝過(guò)程中出現(xiàn)問(wèn)題的解決的文章就介紹到這了,更多相關(guān)docker安裝rocketMQ內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- docker進(jìn)行RocketMq集群部署方式
- Docker安裝部署rocketmq-console工具教程
- 使用Docker容器部署rocketmq單機(jī)的全過(guò)程
- Docker?部署RocketMQ的詳細(xì)操作
- Docker rocketmq部署的實(shí)現(xiàn)示例
- docker安裝RocketMQ的實(shí)現(xiàn)步驟
- 超詳細(xì)Docker Desktop下安裝rocketmq的教程
- docker安裝rocketMQ教程(最詳細(xì))
- Docker中RocketMQ的安裝與使用詳解
- Docker部署RocketMQ的實(shí)現(xiàn)示例
相關(guān)文章
解決Docker報(bào)錯(cuò):“docker build“ requires exactly&nb
這篇文章主要介紹了解決Docker報(bào)錯(cuò):“docker build“ requires exactly 1 argument.具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Docker attach 命令卡死的問(wèn)題及解決方案
Docker 是一種輕量級(jí)的容器化平臺(tái),可以實(shí)現(xiàn)快速部署、運(yùn)行和管理應(yīng)用程序,這篇文章給大家介紹Docker attach 命令卡死的解決方案,感興趣的朋友一起看看吧2023-12-12解決docker加載新的鏡像后repository和tag名稱都為none的問(wèn)題
這篇文章主要介紹了解決docker加載新的鏡像后repository和tag名稱都為none的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11淺談Docker安全機(jī)制內(nèi)核安全與容器之間的網(wǎng)絡(luò)安全
這篇文章主要介紹了Docker安全機(jī)制內(nèi)核安全與容器之間的網(wǎng)絡(luò)安全,具有一定參考價(jià)值,需要的朋友可以了解下。2017-09-09docker如何部署帶有界面的registry倉(cāng)庫(kù)
這篇文章主要介紹了docker如何部署帶有界面的registry倉(cāng)庫(kù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02使用 kind 和 Docker 啟動(dòng)本地的 Kubernetes環(huán)境
這篇文章主要介紹了使用 kind 和 Docker 啟動(dòng)本地的 Kubernetes環(huán)境,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05Docker中優(yōu)化Mysql運(yùn)行內(nèi)存的操作
這篇文章主要介紹了Docker當(dāng)中優(yōu)化Mysql運(yùn)行內(nèi)存的操作,經(jīng)過(guò)一番操作可以優(yōu)化為只占用100mb內(nèi)存,具體優(yōu)化方法及技巧跟隨小編一起看看吧2022-01-01