Springboot RocketMq實現(xiàn)過程詳解
首先,在虛擬機上安裝rocketmq和rocketMq可視化控制,安裝不做描述。
1、pom.xml文件添加依賴
mq的版本與連接的rocketmq版本保持一致
<dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-remoting</artifactId> <version>4.4.0</version> </dependency>
2、yml文件添加rocketmq配置
apache: rocketmq: #消費者的配置 consumer: pushConsumer: myConsumer #生產(chǎn)者的配置 producer: producerGroup: myGroup namesrvAddr: 192.168.233.128:9876
3、生產(chǎn)者類RocketProducer
package com.zp.springbootdemo.rocketmq; import com.alibaba.fastjson.JSONObject; import com.sun.org.apache.xpath.internal.objects.XString; import org.apache.rocketmq.client.exception.MQBrokerException; import org.apache.rocketmq.client.exception.MQClientException; import org.apache.rocketmq.client.producer.DefaultMQProducer; import org.apache.rocketmq.client.producer.SendResult; import org.apache.rocketmq.common.message.Message; import org.apache.rocketmq.remoting.common.RemotingHelper; import org.apache.rocketmq.remoting.exception.RemotingException; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import org.springframework.util.StopWatch; import javax.annotation.PostConstruct; import java.io.UnsupportedEncodingException; /** * @Author zp * @Description rocketmq生產(chǎn)者 * @Date 22:06 2020/5/22 * @Param * @return **/ @Component public class RocketProducer { /** * 生產(chǎn)者的組名 */ @Value("${apache.rocketmq.producer.producerGroup}") private String producerGroup; /** * NameServer 地址 */ @Value("${apache.rocketmq.namesrvAddr}") private String namesrvAddr; private DefaultMQProducer defaultMQProducer; @PostConstruct public void defaultMQProducer(){ //生產(chǎn)者的組名 defaultMQProducer = new DefaultMQProducer(producerGroup); defaultMQProducer.setNamesrvAddr(namesrvAddr); defaultMQProducer.setVipChannelEnabled(false); try { defaultMQProducer.start(); System.out.println("producer啟動了。。。"); } catch (MQClientException e) { e.printStackTrace(); } } public String send(String topic,String tags,String body) throws UnsupportedEncodingException, InterruptedException, RemotingException, MQClientException, MQBrokerException { Message message = new Message(topic,tags,body.getBytes(RemotingHelper.DEFAULT_CHARSET)); StopWatch stop = new StopWatch(); stop.start(); SendResult result = defaultMQProducer.send(message); System.out.println("發(fā)送響應(yīng):MsgId:" + result.getMsgId() + ",發(fā)送狀態(tài):" + result.getSendStatus()); JSONObject jsonObject = new JSONObject(); jsonObject.put("msgId",result.getMsgId()); jsonObject.put("sendStatus",result.getSendStatus()); stop.stop(); return jsonObject.toJSONString(); } }
4、消費者類RocketConsumer
package com.zp.springbootdemo.rocketmq; import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer; import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus; import org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently; import org.apache.rocketmq.client.exception.MQClientException; import org.apache.rocketmq.common.consumer.ConsumeFromWhere; import org.apache.rocketmq.common.message.Message; import org.apache.rocketmq.remoting.CommandCustomHeader; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.CommandLineRunner; import org.springframework.stereotype.Component; /** * @Author zp * @Description rocketmq消費者 * @Date 22:33 2020/5/22 * @Param * @return **/ @Component public class RockerConsumer implements CommandLineRunner { /** * 消費者 */ @Value("${apache.rocketmq.consumer.pushConsumer}") private String pushConsumer; //myConsumer /** * NameServer 地址 */ @Value("${apache.rocketmq.namesrvAddr}") private String namesrvAddr; /** * 初始化RocketMq的監(jiān)聽信息,渠道信息 */ public void messageListener(){ DefaultMQPushConsumer consumer = new DefaultMQPushConsumer(pushConsumer); consumer.setNamesrvAddr(namesrvAddr); try { // 訂閱PushTopic下Tag為push的消息,都訂閱消息 consumer.subscribe("firstTopic","push"); // 程序第一次啟動從消息隊列頭獲取數(shù)據(jù) consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET); //可以修改每次消費消息的數(shù)量,默認設(shè)置是每次消費一條 consumer.setConsumeMessageBatchMaxSize(1); //在此監(jiān)聽中消費信息,并返回消費的狀態(tài)信息 consumer.registerMessageListener((MessageListenerConcurrently) (msgs,context)->{ // 會把不同的消息分別放置到不同的隊列中 for (Message msg:msgs){ System.out.println("接收到了消息:"+new String(msg.getBody())); } return ConsumeConcurrentlyStatus.CONSUME_SUCCESS; }); consumer.start(); } catch (Exception e) { e.printStackTrace(); } } /** * Callback used to run the bean. * * @param args incoming main method arguments * @throws Exception on error */ @Override public void run(String... args) throws Exception { this.messageListener(); } }
5、controller中編寫發(fā)送消息
package com.zp.springbootdemo.rocketmq; import org.apache.rocketmq.client.exception.MQBrokerException; import org.apache.rocketmq.client.exception.MQClientException; import org.apache.rocketmq.remoting.exception.RemotingException; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.io.UnsupportedEncodingException; @RestController @RequestMapping("/rocketMq") public class MQController { @Autowired private RocketProducer producer; @RequestMapping("/myFirstProducer") public String pushMsg(String msg){ try { System.out.println("======"+msg); return producer.send("firstTopic","push",msg); } catch (InterruptedException e) { e.printStackTrace(); } catch (RemotingException e) { e.printStackTrace(); } catch (MQClientException e) { e.printStackTrace(); } catch (MQBrokerException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return "ERROR"; } }
6.測試
請求地址:http://127.0.0.1:8080/rocketMq/myFirstProducer?msg=hello
響應(yīng):{"msgId":"C0A8010E1A3818B4AAC2711E8CD50000","sendStatus":"SEND_OK"}
通過rocketMq可視化控制查看:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot集成RocketMQ發(fā)送事務(wù)消息的原理解析
- Springboot詳解RocketMQ實現(xiàn)消息發(fā)送與接收流程
- Springboot詳細講解RocketMQ實現(xiàn)順序消息的發(fā)送與消費流程
- SpringBoot整合RocketMQ實現(xiàn)消息發(fā)送和接收的詳細步驟
- 解決SpringBoot整合RocketMQ遇到的坑
- springboot整合rocketmq實現(xiàn)分布式事務(wù)
- springBoot整合RocketMQ及坑的示例代碼
- 淺談Springboot整合RocketMQ使用心得
- SpringBoot整合RocketMQ的詳細過程
相關(guān)文章
SpringBoot如何使用Undertow做服務(wù)器
這篇文章主要介紹了SpringBoot如何使用Undertow做服務(wù)器,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07在非spring環(huán)境中調(diào)用service中的方法
非Spring環(huán)境指的是不使用Spring框架來管理和配置應(yīng)用程序的運行時環(huán)境,本文將給大家介紹如何在非spring環(huán)境中調(diào)用service中的方法,文中有詳細實現(xiàn)步驟,需要的朋友可以參考下2024-03-03解決CollectionUtils.isNotEmpty()不存在的問題
這篇文章主要介紹了解決CollectionUtils.isNotEmpty()不存在的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02新版本IntelliJ IDEA 構(gòu)建maven,并用Maven創(chuàng)建一個web項目(圖文教程)
這篇文章主要介紹了新版本IntelliJ IDEA 構(gòu)建maven,并用Maven創(chuàng)建一個web項目的圖文教程,需要的朋友可以參考下2018-01-01使用fastjson中的JSONPath處理json數(shù)據(jù)的方法
這篇文章主要介紹了使用fastjson中的JSONPath處理json數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04