spring-boot-route(十五)整合RocketMQ
- 2020 年 10 月 14 日
- 筆記
- spring-boot-route
RocketMQ簡介
RocketMQ是阿里巴巴開源的消息中間件。目前已經貢獻給Apache軟體基金會,成為Apache的頂級項目。
rocketMQ基本概念
1. Producer Group
生產者組:是一類生產者的集合,通常發送同一類消息並且發送邏輯一致。
2. Producer
生產者:負責發送消息,有三種消息發送模式。
- 同步發送:收到確認後再發送下一條消息
- 非同步發送:發送後,不等待確認繼續發送下一條
- 單向發送:只負責發送消息,無法確認並且沒有回調,適合收集日誌
3. Consumer Group
消費者組:是一類消費者的集合,通常消費同一類消息並且消費邏輯一致。
4. Consumer
消息者:負責消費消息,有兩種消費模式
- 拉取型消費:主動從消息伺服器拉取資訊,只要批量拉取到消息,用戶應用就會啟動消費過程
- 推送型消費:實際上也是拉取消息,只不過是將拉取邏輯進行了封裝,將消息到達時執行的回調介面留給用戶來實現
5. Broker
消息伺服器:存儲消息
6. NameServer
作用和zookeeper類似,用來保存broker相關元素,並給producer和consumer查找broker消息,Producer 在發送消息前會根據 Topic 到 NameServer 獲取到 Broker 的路由資訊,Consumer 也會定時獲取 Topic 的路由資訊。
7. Topic
消息主題
8. Tag
標籤,Topic的二級分類,也可以理解為消息隊列,主題被劃分為一個或多個子主題,即消息隊列。一個 Topic 下可以設置多個消息隊列,發送消息時執行該消息的 Topic ,RocketMQ 會輪詢該 Topic 下的所有隊列將消息發出去。
Spring Boot整合Rocketmq
1. 引入依賴
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.1.0</version>
</dependency>
2. 配置rocketmq資訊
rocketmq:
name-server: 127.0.0.1:9876
producer:
group: my-producer-group
3. 構建生產者
@RestController
public class Producer {
@Autowired
private RocketMQTemplate rocketMQTemplate;
@GetMapping("send")
public void send(){
rocketMQTemplate.convertAndSend("first-topic","你好,Java旅途");
}
}
4. 構建消費者
@Component
@RocketMQMessageListener(topic = "first-topic",consumerGroup = "my-consumer-group")
@Slf4j
public class Consumer implements RocketMQListener<String> {
@Override
public void onMessage(String message) {
log.info("我收到消息了!消息內容為:"+message);
}
}
emmm,消息隊列的內容就暫時告一段落了,文章中只是演示了最簡單的收發消息,在實際應用中需要考慮的問題遠比這要多。
此是spring-boot-route系列的第十五篇文章,這個系列的文章都比較簡單,主要目的就是為了幫助初次接觸Spring Boot 的同學有一個系統的認識。本文已收錄至我的github,歡迎各位小夥伴star
!
github://github.com/binzh303/spring-boot-route
點關注、不迷路
如果覺得文章不錯,歡迎關注、點贊、收藏,你們的支援是我創作的動力,感謝大家。
如果文章寫的有問題,請不要吝嗇,歡迎留言指出,我會及時核查修改。
如果你還想更加深入的了解我,可以微信搜索「Java旅途」進行關注。回復「1024」即可獲得學習影片及精美電子書。每天7:30準時推送技術文章,讓你的上班路不在孤獨,而且每月還有送書活動,助你提升硬實力!