RocketMQTemplate 註入失敗的解決
RocketMQTemplate 註入失敗
在使用rocketmq 發送消息時,會發現
@Autowired private RocketMQTemplate rocketMQTemplate;
註入RocketMQTemplate 失敗。
解決方案
究其原因是因為,配置文件中,我們沒有添加
上圖中藍色的兩行代碼,指定發送的組名。寫上後,問題解決。
好瞭,再來說說RocketMQTemplate 的基本使用吧~
RocketMQTemplate的使用
1、pom.xml依賴
<dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-spring-boot-starter</artifactId> <version>2.0.3</version> </dependency> <dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>4.5.1</version> </dependency> <dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-common</artifactId> <version>4.5.1</version> </dependency>
2、配置文件
# 必須配置 # 指定nameServer rocketmq.nameServer=192.168.168.168:9876 # 指定發送者組名 相當於rabbitmq的virtual host 邏輯上的劃分 rocketmq.producer.group=my-group # 其他可選配置 #rocketmq.producer.send-message-timeout=300000 #rocketmq.producer.compress-message-body-threshold=4096 #rocketmq.producer.max-message-size=4194304 #rocketmq.producer.retry-times-when-send-async-failed=0 #rocketmq.producer.retry-next-server=true #rocketmq.producer.retry-times-when-send-failed=2
3、RocketMQTemplate的基本方法
首先使用@Autowired註入MongoTemplate(後面直接使用,就不特殊說明)
@Autowired private RocketMQTemplate rocketMQTemplate;
簡單使用
//發送消息 public class ProducerController { @Autowired private RocketMQTemplate rocketMQTemplate; public void send(){ //實體類User User user=new User(999L,"testUser"); //發送自定義對象 rocketMQTemplate.convertAndSend("test_topic",user);//會自動轉換為json格式 } }
//接收消息 @Component //必須註入spring容器 @RocketMQMessageListener( topic = "test_topic", //topic:消息的發送者使用同一個topic consumerGroup = "test_my-consumer", //group:不用和生產者group相同 selectorExpression = "*") //tag // 在RocketMQ中消費者和發送者組沒有關系 // 如果兩個消費者groupname和topic都一樣,則二者輪循接收消息 // 如果兩個消費者topic一樣,而group不一樣,則消息變成廣播機制 // RocketMQListener<>泛型必須和接收的消息類型相同 public class TestListner implements RocketMQListener<User> { private static final ObjectMapper MAPPER = new ObjectMapper(); @Override public void onMessage(User user) { JsonNode jsonNode = MAPPER.readTree(user);//可以使用mapper讀取json格式數據 Long userId = jsonNode.get("userId").asLong(); System.out.println(user); } }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- SpringBoot整合RocketMQ實現消息發送和接收的詳細步驟
- springboot整合rocketmq實現分佈式事務
- Springboot詳解RocketMQ實現廣播消息流程
- Springboot 整合 RocketMQ 收發消息的配置過程
- 解決springboot集成rocketmq關於tag的坑