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。

推薦閱讀: