欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年07月02日 12:04:18   作者:樓蘭的胡楊  
這篇文章主要介紹了Spring Boot ActiveMQ發(fā)布/訂閱消息模式原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

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

發(fā)布/訂閱模式的工作示意圖

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

和點對點方式不同,發(fā)布到topic的消息會被所有訂閱者消費;當生產(chǎn)者發(fā)布消息時,不管是否有消費者,都不會保存消息;一定要先有消息的消費者,后有消息的生產(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
#默認值false,表示point to point(點到點)模式,true時代表發(fā)布訂閱模式,需要手動開啟
#spring.jms.pub-sub-domain=true

創(chuàng)建生產(chǎn)者和消費者

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;

/**
 * 消費者
 */
@Service
public 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;

/**
 * 消費者
 */
@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 收到的報文:{}", text);
  }

}

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

測試發(fā)布訂閱模式

創(chuàng)建Junit測試用例:

@Test
  public void topicTest() {
    // 設置話題監(jiān)聽者,可以自由切換
    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。發(fā)布/訂閱模式和點對點模式的生產(chǎn)者的代碼主要區(qū)別就是Destination的創(chuàng)建方式,點對點模式是調用new ActiveMQQueue (QUEUE_NAME),而發(fā)布/訂閱模式是調用new ActiveMQTopic (QUEUE_NAME)。

執(zhí)行結果:

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

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

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

相關文章

  • IDEA2022中部署Tomcat Web項目的流程分析

    IDEA2022中部署Tomcat Web項目的流程分析

    這篇文章主要介紹了IDEA2022中部署Tomcat Web項目,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • Springboot之idea之pom文件圖標不對問題

    Springboot之idea之pom文件圖標不對問題

    這篇文章主要介紹了Springboot之idea之pom文件圖標不對問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java后端學習精華之TCP通信傳輸協(xié)議詳解

    Java后端學習精華之TCP通信傳輸協(xié)議詳解

    TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission Control Protocol,它是位于網(wǎng)絡OSI模型中的第四層
    2021-09-09
  • SpringBoot 分布式驗證碼登錄方案示例詳解

    SpringBoot 分布式驗證碼登錄方案示例詳解

    為了防止驗證系統(tǒng)被暴力破解,很多系統(tǒng)都增加了驗證碼效驗,比較常見的就是圖片二維碼,業(yè)內比較安全的是短信驗證碼,當然還有一些拼圖驗證碼,加入人工智能的二維碼等等,我們今天的主題就是前后端分離的圖片二維碼登錄方案,感興趣的朋友一起看看吧
    2023-10-10
  • 解決springboot URL帶有斜杠的轉義字符百分之2F導致的400錯誤

    解決springboot URL帶有斜杠的轉義字符百分之2F導致的400錯誤

    這篇文章主要介紹了解決springboot URL帶有斜杠的轉義字符百分之2F導致的400錯誤問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java超詳細教你寫一個學籍管理系統(tǒng)案例

    Java超詳細教你寫一個學籍管理系統(tǒng)案例

    這篇文章主要介紹了怎么用Java來寫一個學籍管理系統(tǒng),學籍管理主要涉及到學生信息的增刪查改,本篇將詳細的實現(xiàn),感興趣的朋友跟隨文章往下看看吧
    2022-03-03
  • 深入理解Java反射

    深入理解Java反射

    在理解反射原理之前先要搞清類型信息。接下來通過本文給大家介紹java反射的深入理解,非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧
    2016-07-07
  • SpringCloud Feign高級配置詳解

    SpringCloud Feign高級配置詳解

    這篇文章主要介紹了SpringCloud Feign高級配置,feign是netflix提供的服務間基于http的rpc調用框架,在spring cloud得到廣泛應用
    2022-09-09
  • java中的各種修飾符作用及范圍

    java中的各種修飾符作用及范圍

    這篇文章主要介紹了java中的各種修飾符作用及范圍,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • spring-cloud入門之eureka-server(服務發(fā)現(xiàn))

    spring-cloud入門之eureka-server(服務發(fā)現(xiàn))

    本篇文章主要介紹了spring-cloud入門之eureka-server(服務發(fā)現(xiàn)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01

最新評論