Window搭建部署RocketMQ步驟詳解
序
以前簡單用過ActiveMQ但是公司項(xiàng)目上使用的是RocketMQ,所以準(zhǔn)備多花點(diǎn)時(shí)間在這上面,搞懂項(xiàng)目的配置使用。
看了很多資料,先說說我自己對(duì)RocketMQ的簡單理解。不管是我們寫的消費(fèi)者還是生產(chǎn)者都屬于客戶端,而我們需要安裝RocketMQ,這是屬于服務(wù)端。和ActivieMQ、zookeeper類似,消費(fèi)者、生成者、服務(wù)端(NameServer)之間是采取觀察者模式實(shí)現(xiàn)。
在操作系統(tǒng)上安裝RocketMQ,啟動(dòng)服務(wù)端NameServer、啟動(dòng)Broker,書寫Consumer代碼,運(yùn)行消費(fèi)者。書寫Producer代碼,運(yùn)行生產(chǎn)者。
基本簡單邏輯是這樣的,當(dāng)然其中還有很多細(xì)節(jié)。平時(shí)在測試時(shí)我們都在window上使用,踩了點(diǎn)坑,成功完成。
安裝運(yùn)行
1、下載
建議下載發(fā)行版本,我試過自己編譯,不知道為何報(bào)錯(cuò)了。
rocketmq-all-4.2.0-bin-release.zip
解壓出來如下:
2、啟動(dòng)
NameServer
在啟動(dòng)之前需要配置系統(tǒng)環(huán)境,不然會(huì)報(bào)錯(cuò)。配置完成記得重啟電腦
Please set the ROCKETMQ_HOME variable in your environment!
系統(tǒng)環(huán)境變量名:ROCKETMQ_HOME
每個(gè)人不一樣,對(duì)比如上我的路徑—-變量值:D:\rocketMQ
進(jìn)入window命令窗口,進(jìn)入bin目錄下,執(zhí)行
start mqnamesrv.cmd
如上則NameServer啟動(dòng)成功。使用期間,窗口不要關(guān)機(jī)。
Broker
同理,再次開一個(gè)命令窗口,進(jìn)入bin目錄下,輸入
start mqbroker.cmd -n localhost:9876
如上的 ip+port 是NameServer的進(jìn)程,因?yàn)镹ameser安裝啟動(dòng)在本地,所以這里的 ip 是 localhost。
運(yùn)行如上命令,可能會(huì)報(bào)如下錯(cuò)誤。找不到或無法加載主類
如果出此情況,打開bin-->runbroker.cmd,修改%CLASSPATH%成
"%CLASSPATH%"
保存再次執(zhí)行如上命令。執(zhí)行成功后,窗口并不會(huì)顯示什么,只是一個(gè)空窗口,代表成功。
書寫代碼
依賴RocketMQ
<dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>4.2.0</version> </dependency>
1、Consumer
public class Consumer { public static void main(String[] args) throws MQClientException { //這里填寫group名字 DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("my-group-name-A"); //NameServer地址 consumer.setNamesrvAddr("localhost:9876"); //1:topic名字 2:tag名字 consumer.subscribe("topic-name-A", "tag-name-A"); consumer.registerMessageListener(new MessageListenerConcurrently() { @Override public ConsumeConcurrentlyStatus consumeMessage( List<MessageExt> msgs, ConsumeConcurrentlyContext context) { for (MessageExt msg : msgs) { System.out.println(new String(msg.getBody())); } return ConsumeConcurrentlyStatus.CONSUME_SUCCESS; } }); consumer.start(); System.out.println("Consumer Started!"); } }
先運(yùn)行起來
2、Producer
注意匹配相應(yīng)參數(shù):group topic tag
public class Producer { public static void main(String[] args) throws MQClientException, RemotingException, InterruptedException, MQBrokerException { DefaultMQProducer producer = new DefaultMQProducer("my-group-name-A"); producer.setNamesrvAddr("localhost:9876"); producer.start(); Message message = new Message("topic-name-A","tag-name-A","Message : My blog address guozh.net".getBytes()); producer.send(message); System.out.println("Message sended"); producer.shutdown(); } }
再次運(yùn)行 producer。
然后去 Consumer 看看是否收到消息。
監(jiān)控平臺(tái)
和其他的MQ一樣,這里也提供了Window版本可視化的監(jiān)控和 Linux監(jiān)控??梢钥吹较⑾M(fèi)的具體情況,但是其實(shí)在實(shí)際開發(fā)過程中,Window顯示的界面數(shù)據(jù)非常少,看不到多少內(nèi)容。所以實(shí)際項(xiàng)目中都是看 Linux 數(shù)據(jù)。
我們這邊項(xiàng)目看MQ消費(fèi)情況也是在Linux上部署查看。
但是可以學(xué)習(xí)學(xué)習(xí),為Linux的安裝拓展畫面感。
1、下載
其實(shí)這里提供了安裝部署的方法,可以根據(jù)實(shí)際情況來
所以一步一步來吧,首先修改配置文件。修改application.properties,具體位置如下
rocketmq-console\src\main\resources
主要如上兩處需要修改,平臺(tái)部署的端口。我這里 8080 沒被使用,這里就用 8080。下面是NameServer的啟動(dòng)位置,根據(jù)自己實(shí)際情況填寫即可。
2、啟動(dòng)
首先,上面的 Tips 也說了,看看自己的Maven鏡像是不是阿里云的,不然下載jar可能下載不下來或者很慢,這里不用說了。
進(jìn)入命令窗口,進(jìn)入rocketmq-console目錄,執(zhí)行。
mvn clean package -Dmaven.test.skip=true
Build成功后,再次執(zhí)行
java -jar target/rocketmq-console-ng-1.0.0.jar
完成后,進(jìn)入網(wǎng)址即可,比如我這是 localhost:8080
ok!完成,估計(jì)后面會(huì)好好的學(xué)習(xí)RocketMQ。
相關(guān)文章
Spring實(shí)戰(zhàn)之Bean銷毀之前的行為操作示例
這篇文章主要介紹了Spring實(shí)戰(zhàn)之Bean銷毀之前的行為操作,結(jié)合實(shí)例形式分析了spring在bean銷毀之前的行為相關(guān)設(shè)置與使用技巧,需要的朋友可以參考下2019-11-11Java求字符串中出現(xiàn)次數(shù)最多的字符串以及出現(xiàn)次數(shù)
這篇文章主要為大家詳細(xì)介紹了Java統(tǒng)計(jì)字符串中出現(xiàn)次數(shù)最多的字符串以及出現(xiàn)次數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04解決idea刪除模塊后重新創(chuàng)建顯示該模塊已經(jīng)被注冊(cè)的問題
這篇文章主要介紹了解決idea刪除模塊后重新創(chuàng)建顯示該模塊已經(jīng)被注冊(cè)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02mybatis一級(jí)緩存和二級(jí)緩存的區(qū)別及說明
這篇文章主要介紹了mybatis一級(jí)緩存和二級(jí)緩存的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11深入解析Java的Hibernate框架中的持久對(duì)象
Hibernate的持久對(duì)象在數(shù)據(jù)庫數(shù)據(jù)操作中有著重要作用,這里我們就來深入解析Java的Hibernate框架中的持久對(duì)象,首先必須從理解持久化對(duì)象的生命周期開始:2016-07-07Java根據(jù)坐標(biāo)經(jīng)緯度計(jì)算兩點(diǎn)距離5種方法及校驗(yàn)經(jīng)緯度是否在圓/多邊形區(qū)域內(nèi)的算法推薦
在項(xiàng)目開發(fā)過程中需要根據(jù)兩地經(jīng)緯度坐標(biāo)計(jì)算兩地間距離,下面這篇文章主要給大家介紹了關(guān)于Java根據(jù)坐標(biāo)經(jīng)緯度計(jì)算兩點(diǎn)距離5種方法以及校驗(yàn)經(jīng)緯度是否在圓/多邊形區(qū)域內(nèi)的算法推薦,需要的朋友可以參考下2023-12-12