91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring Boot ActiveMQ發布/訂閱消息模式的原理是什么

發布時間:2020-07-02 14:25:22 來源:億速云 閱讀:278 作者:清晨 欄目:開發技術

這篇文章主要介紹Spring Boot ActiveMQ發布/訂閱消息模式的原理是什么,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

介紹如何使用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:61616
spring.activemq.in-memory=true
spring.activemq.pool.enabled=false
spring.activemq.password=admin
spring.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;

/**
 * 生產者
 */
@Service
public 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;

/**
 * 消費者
 */
@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);
  }

}

發布訂閱模式和點對點模式的消費者沒有區別,換換監聽對象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 0
Subscriber2 隊列收到的報文:Topic Message 1
Subscriber2 隊列收到的報文:Topic Message 2
Subscriber2 隊列收到的報文:Topic Message 3
Subscriber2 隊列收到的報文:Topic Message 4
Subscriber2 隊列收到的報文:Topic Message 5

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

以上是Spring Boot ActiveMQ發布/訂閱消息模式的原理是什么的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

金沙县| 凤凰县| 禄丰县| 兴化市| 库尔勒市| 马边| 华坪县| 潢川县| 吉木乃县| 定陶县| 托里县| 鹿邑县| 麦盖提县| 乐平市| 岗巴县| 巨野县| 海丰县| 汉中市| 邹平县| 银川市| 高尔夫| 五大连池市| 罗甸县| 嵊州市| 五常市| 灌南县| 汾阳市| 武清区| 富平县| 新化县| 溧阳市| 平山县| 丹东市| 阜平县| 满城县| 金川县| 福清市| 景东| 崇州市| 抚松县| 丹巴县|