av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Spring Boot ActiveMQ發布/訂閱消息模式原理解析

瀏覽:21日期:2023-08-30 09:00:47

本文在《Spring Boot基于Active MQ實現整合JMS》的基礎上,介紹如何使用ActiveMQ的發布/訂閱消息模式。發布/訂閱消息模式是消息發送者發送消息到主題(topic),而多個消息接收者監聽這個主題;其中,消息發送者和接收者分別叫做發布者(publisher)和訂閱者(subscriber),對于發布者來說,它和所有的訂閱者就構成了一個1對多的關系。這種關系如下圖所示:

Spring Boot ActiveMQ發布/訂閱消息模式原理解析

發布/訂閱模式的工作示意圖

消息生產者將消息(發布)到topic中,可以同時有多個消息消費者(訂閱)消費該消息。

和點對點方式不同,發布到topic的消息會被所有訂閱者消費;當生產者發布消息時,不管是否有消費者,都不會保存消息;一定要先有消息的消費者,后有消息的生產者。

軟件環境

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:61616spring.activemq.in-memory=truespring.activemq.pool.enabled=falsespring.activemq.password=adminspring.activemq.user=admin#默認值false,表示point to point(點到點)模式,true時代表發布訂閱模式,需要手動開啟#spring.jms.pub-sub-domain=true

創建生產者和消費者

import org.springframework.beans.factory.annotation.Autowired;import org.springframework.jms.core.JmsMessagingTemplate;import org.springframework.stereotype.Service;import javax.jms.Destination;/** * 生產者 */@Servicepublic class Publisher { @Autowired private JmsMessagingTemplate jmsMsgTemplate; /** * 發送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;/** * 消費者 */@Servicepublic class Subscriber2 { private static Logger logger = LoggerFactory.getLogger(Subscriber2.class); @JmsListener(destination = 'topicListener2') public void subscriber(String text) { logger.info('Subscriber2 收到的報文:{}', text); }}

import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.jms.annotation.JmsListener;import org.springframework.stereotype.Component;import javax.jms.JMSException;/** * 消費者 */@Componentpublic 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 收到的報文:{}', text); }}

發布訂閱模式和點對點模式的消費者沒有區別,換換監聽對象destination的值就行。接下來測試發布訂閱模式。

測試發布訂閱模式

創建Junit測試用例:

@Test public void topicTest() { // 設置話題監聽者,可以自由切換 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 毫秒,保證消費者消費完畢!'); }

此處設置的訂閱者是topicListener2,讀者可以切換為topicListener1。發布/訂閱模式和點對點模式的生產者的代碼主要區別就是Destination的創建方式,點對點模式是調用new ActiveMQQueue (QUEUE_NAME),而發布/訂閱模式是調用new ActiveMQTopic (QUEUE_NAME)。

執行結果:

Subscriber2 隊列收到的報文:Topic Message 0Subscriber2 隊列收到的報文:Topic Message 1Subscriber2 隊列收到的報文:Topic Message 2Subscriber2 隊列收到的報文:Topic Message 3Subscriber2 隊列收到的報文:Topic Message 4Subscriber2 隊列收到的報文:Topic Message 5

使線程睡 300 毫秒,保證消費者消費完畢!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 欧美一区二区三区,视频 | 国产乱码精品一区二区三区中文 | 久免费视频 | 一级毛片成人免费看a | 成人av片在线观看 | 亚洲成年人免费网站 | 自拍偷拍第一页 | 日韩精品中文字幕一区二区三区 | 九九热精品视频 | 国产乱码久久久久久 | 欧美在线 | 国产精品毛片无码 | 久久高潮 | 一级片免费在线观看 | 国产成人高清在线观看 | 国产精品揄拍一区二区久久国内亚洲精 | 蜜桃精品噜噜噜成人av | 国产精品久久久久久久久久久久午夜片 | av电影手机在线看 | 成人伊人 | 伊人二区 | 中文在线播放 | 国产成人免费网站 | 产真a观专区| 亚洲精品久久久久avwww潮水 | 精品久久久久久亚洲精品 | 超碰在线亚洲 | 97精品超碰一区二区三区 | 欧美一页 | 天天操天天插 | 在线视频成人 | 女人精96xxx免费网站p | 国产精品一区二区三 | 国产精品久久久久不卡 | 国产网站在线播放 | 亚洲国产精品日本 | 一区二区三区免费看 | 欧美不卡 | 日韩电影中文字幕 | 蜜桃久久| 欧美日韩一 |