Spring Boot ActiveMQ發(fā)布/訂閱消息模式原理解析
本文在《Spring Boot基于Active MQ實(shí)現(xiàn)整合JMS》的基礎(chǔ)上,介紹如何使用ActiveMQ的發(fā)布/訂閱消息模式。發(fā)布/訂閱消息模式是消息發(fā)送者發(fā)送消息到主題(topic),而多個(gè)消息接收者監(jiān)聽(tīng)這個(gè)主題;其中,消息發(fā)送者和接收者分別叫做發(fā)布者(publisher)和訂閱者(subscriber),對(duì)于發(fā)布者來(lái)說(shuō),它和所有的訂閱者就構(gòu)成了一個(gè)1對(duì)多的關(guān)系。這種關(guān)系如下圖所示:
發(fā)布/訂閱模式的工作示意圖
消息生產(chǎn)者將消息(發(fā)布)到topic中,可以同時(shí)有多個(gè)消息消費(fèi)者(訂閱)消費(fèi)該消息。
和點(diǎn)對(duì)點(diǎn)方式不同,發(fā)布到topic的消息會(huì)被所有訂閱者消費(fèi);當(dāng)生產(chǎn)者發(fā)布消息時(shí),不管是否有消費(fèi)者,都不會(huì)保存消息;一定要先有消息的消費(fèi)者,后有消息的生產(chǎn)者。
軟件環(huán)境
- ActiveMQ 5.15.13
- java version 13.0.1
- IntelliJ IDEA 2019.3.2 (Ultimate Edition)
- Spring Boot 2.3.0.RELEASE
配置ActiveMQ連接信息
spring.activemq.broker-url=tcp://127.0.0.1:61616 spring.activemq.in-memory=true spring.activemq.pool.enabled=false spring.activemq.password=admin spring.activemq.user=admin #默認(rèn)值false,表示point to point(點(diǎn)到點(diǎn))模式,true時(shí)代表發(fā)布訂閱模式,需要手動(dòng)開(kāi)啟 #spring.jms.pub-sub-domain=true
創(chuàng)建生產(chǎn)者和消費(fèi)者
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jms.core.JmsMessagingTemplate; import org.springframework.stereotype.Service; import javax.jms.Destination; /** * 生產(chǎn)者 */ @Service public class Publisher { @Autowired private JmsMessagingTemplate jmsMsgTemplate; /** * 發(fā)送topic * * @param destination * @param message */ public void publish(Destination destination, String message) { jmsMsgTemplate.convertAndSend(destination, message); } }
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jms.annotation.JmsListener; import org.springframework.stereotype.Service; /** * 消費(fèi)者 */ @Service public class Subscriber2 { private static Logger logger = LoggerFactory.getLogger(Subscriber2.class); @JmsListener(destination = "topicListener2") public void subscriber(String text) { logger.info("Subscriber2 收到的報(bào)文:{}", text); } }
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jms.annotation.JmsListener; import org.springframework.stereotype.Component; import javax.jms.JMSException; /** * 消費(fèi)者 */ @Component public class Subscriber1 { private static Logger logger = LoggerFactory.getLogger(Subscriber1.class); /** * 訂閱 topicListener1 * * @param text * @throws JMSException */ @JmsListener(destination = "topicListener1") public void subscriber(String text) { logger.info("Subscriber1 收到的報(bào)文:{}", text); } }
發(fā)布訂閱模式和點(diǎn)對(duì)點(diǎn)模式的消費(fèi)者沒(méi)有區(qū)別,換換監(jiān)聽(tīng)對(duì)象destination的值就行。接下來(lái)測(cè)試發(fā)布訂閱模式。
測(cè)試發(fā)布訂閱模式
創(chuàng)建Junit測(cè)試用例:
@Test public void topicTest() { // 設(shè)置話題監(jiān)聽(tīng)者,可以自由切換 Destination destination = new ActiveMQTopic("topicListener2"); for (int i = 0; i < 6; i++) { publisher.publish(destination, "Topic Message " + i); } try { Thread.sleep(300); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("使線程睡 300 毫秒,保證消費(fèi)者消費(fèi)完畢!"); }
此處設(shè)置的訂閱者是topicListener2,讀者可以切換為topicListener1。發(fā)布/訂閱模式和點(diǎn)對(duì)點(diǎn)模式的生產(chǎn)者的代碼主要區(qū)別就是Destination的創(chuàng)建方式,點(diǎn)對(duì)點(diǎn)模式是調(diào)用new ActiveMQQueue (QUEUE_NAME),而發(fā)布/訂閱模式是調(diào)用new ActiveMQTopic (QUEUE_NAME)。
執(zhí)行結(jié)果:
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 0
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 1
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 2
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 3
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 4
Subscriber2 隊(duì)列收到的報(bào)文:Topic Message 5
使線程睡 300 毫秒,保證消費(fèi)者消費(fèi)完畢!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
IDEA2022中部署Tomcat Web項(xiàng)目的流程分析
這篇文章主要介紹了IDEA2022中部署Tomcat Web項(xiàng)目,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03Springboot之idea之pom文件圖標(biāo)不對(duì)問(wèn)題
這篇文章主要介紹了Springboot之idea之pom文件圖標(biāo)不對(duì)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04Java后端學(xué)習(xí)精華之TCP通信傳輸協(xié)議詳解
TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會(huì)保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission Control Protocol,它是位于網(wǎng)絡(luò)OSI模型中的第四層2021-09-09SpringBoot 分布式驗(yàn)證碼登錄方案示例詳解
為了防止驗(yàn)證系統(tǒng)被暴力破解,很多系統(tǒng)都增加了驗(yàn)證碼效驗(yàn),比較常見(jiàn)的就是圖片二維碼,業(yè)內(nèi)比較安全的是短信驗(yàn)證碼,當(dāng)然還有一些拼圖驗(yàn)證碼,加入人工智能的二維碼等等,我們今天的主題就是前后端分離的圖片二維碼登錄方案,感興趣的朋友一起看看吧2023-10-10解決springboot URL帶有斜杠的轉(zhuǎn)義字符百分之2F導(dǎo)致的400錯(cuò)誤
這篇文章主要介紹了解決springboot URL帶有斜杠的轉(zhuǎn)義字符百分之2F導(dǎo)致的400錯(cuò)誤問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Java超詳細(xì)教你寫(xiě)一個(gè)學(xué)籍管理系統(tǒng)案例
這篇文章主要介紹了怎么用Java來(lái)寫(xiě)一個(gè)學(xué)籍管理系統(tǒng),學(xué)籍管理主要涉及到學(xué)生信息的增刪查改,本篇將詳細(xì)的實(shí)現(xiàn),感興趣的朋友跟隨文章往下看看吧2022-03-03spring-cloud入門之eureka-server(服務(wù)發(fā)現(xiàn))
本篇文章主要介紹了spring-cloud入門之eureka-server(服務(wù)發(fā)現(xiàn)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01