Springboot RocketMq實現(xiàn)過程詳解
首先,在虛擬機(jī)上安裝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ù)量,默認(rèn)設(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使用心得
- springBoot整合RocketMQ及坑的示例代碼
- SpringBoot整合RocketMQ實現(xiàn)消息發(fā)送和接收的詳細(xì)步驟
- 解決SpringBoot整合RocketMQ遇到的坑
- SpringBoot整合RocketMQ實現(xiàn)發(fā)送同步消息
- Springboot詳解RocketMQ實現(xiàn)消息發(fā)送與接收流程
- SpringBoot集成RocketMQ的使用示例
- SpringBoot項目嵌入RocketMQ的實現(xiàn)示例
- SpringBoot+RocketMQ實現(xiàn)延遲消息的示例代碼
相關(guān)文章
Spring Boot 自動裝配的幾種用法示例小結(jié)
文章介紹了SpringBoot自動裝配的多種用法,包括基礎(chǔ)的@Bean注冊、策略模式通過applicationContext獲取指定Service實現(xiàn)類,以及高級的獲取接口所有實現(xiàn)類集合和Map映射,感興趣的朋友跟隨小編一起看看吧2025-07-07
SpringCloud?客戶端Ribbon負(fù)載均衡的實現(xiàn)方法
Ribbon 是 Netflix 提供的一個基于 Http 和 TCP 的客戶端負(fù)載均衡工具,且已集成在 Eureka 依賴中,這篇文章主要介紹了SpringCloud?客戶端Ribbon負(fù)載均衡的實現(xiàn)方法,需要的朋友可以參考下2022-06-06
Java事務(wù)管理學(xué)習(xí)之Spring和Hibernate詳解
這篇文章主要給大家介紹了Java事務(wù)管理學(xué)習(xí)之Spring和Hibernate的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們可以參考借鑒,下面來一起看看吧。2017-03-03

