springboot整合activeMQ

来源:https://www.cnblogs.com/qiantao/archive/2020/05/07/12846573.html
-Advertisement-
Play Games

消息隊列中間件是分散式系統中重要的組件,主要解決應用耦合,非同步消息,流量削鋒等問題。實現高性能,高可用,可伸縮和最終一致性架構。是大型分散式系統不可缺少的中間件。消息形式支持點對點和訂閱-發佈。 ActiveMQ是什麼 1、ActiveMQ是消息隊列技術,為解決高併發問題而生 2、ActiveMQ生 ...


  消息隊列中間件是分散式系統中重要的組件,主要解決應用耦合,非同步消息,流量削鋒等問題。實現高性能,高可用,可伸縮和最終一致性架構。是大型分散式系統不可缺少的中間件。消息形式支持點對點和訂閱-發佈。

ActiveMQ是什麼
    1、ActiveMQ是消息隊列技術,為解決高併發問題而生
    2、ActiveMQ生產者消費者模型(生產者和消費者可以跨平臺、跨系統)
    3、ActiveMQ支持如下兩種消息傳輸方式

    • 點對點模式,生產者生產了一個消息,只能由一個消費者進行消費

    • 發佈/訂閱模式,生產者生產了一個消息,可以由多個消費者進行消費

1、安裝activeMQ

  • 下載地址
  • 解壓
  • 進入解壓後的目錄運行 ./bin/activemq start
  • 啟動後activemq會啟動兩個埠:
    • 8161是activemq的管理頁面,預設的賬號密碼都是admin
    • 61616是程式連接activemq的通訊地址

2、項目結構

3、引入依賴

       <!-- activemq依賴 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-activemq</artifactId>
        </dependency>
        
        <!--消息隊列連接池-->
        <!-- 使用springboot2.0+及以下版本時候 -->
        <!-- <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-pool</artifactId>
            <version>5.15.0</version>
        </dependency> -->
        <!-- 使用springboot2.1+時候 -->
        <dependency>
            <groupId>org.messaginghub</groupId>
            <artifactId>pooled-jms</artifactId>
        </dependency>

3、修改application.properties

#服務埠號
server.port=8080
server.servlet.context-path=/activemqsb

#activemq配置
#ActiveMQ通訊地址
spring.activemq.broker-url=tcp://localhost:61616
#用戶名
spring.activemq.user=admin
#密碼
spring.activemq.password=admin
#是否啟用記憶體模式(就是不安裝MQ,項目啟動時同時啟動一個MQ實例)
spring.activemq.in-memory=false
#信任所有的包
spring.activemq.packages.trust-all=true
#是否替換預設的連接池,使用ActiveMQ的連接池需引入的依賴
spring.activemq.pool.enabled=false

4、配置activeMQ

@Configuration
@EnableJms
public class ActiveMQConfig {
    @Bean
    public Queue queue() {
        return new ActiveMQQueue("springboot.queue") ;
    }

    //springboot預設只配置queue類型消息,如果要使用topic類型的消息,則需要配置該bean
    @Bean
    public JmsListenerContainerFactory jmsTopicListenerContainerFactory(ConnectionFactory connectionFactory){
        DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        //這裡必須設置為true,false則表示是queue類型
        factory.setPubSubDomain(true);
        return factory;
    }

    @Bean
    public Topic topic() {
        return new ActiveMQTopic("springboot.topic") ;
    }
}

5、創建消費者

@Service
//消費者
public class Consumer {
    //接收queue類型消息
    //destination對應配置類中ActiveMQQueue("springboot.queue")設置的名字
    @JmsListener(destination="springboot.queue")
    public void ListenQueue(String msg){
        System.out.println("接收到queue消息:" + msg);
    }

    //接收topic類型消息
    //destination對應配置類中ActiveMQTopic("springboot.topic")設置的名字
    //containerFactory對應配置類中註冊JmsListenerContainerFactory的bean名稱
    @JmsListener(destination="springboot.topic", containerFactory = "jmsTopicListenerContainerFactory")
    public void ListenTopic(String msg){
        System.out.println("接收到topic消息:" + msg);
    }
}

6、創建生產者

@RestController
//生產者
public class Producer {
    
    @Autowired
    private JmsMessagingTemplate jmsTemplate;

    @Autowired
    private Queue queue;

    @Autowired
    private Topic topic;

    //發送queue類型消息
    @GetMapping("/queue")
    public void sendQueueMsg(String msg){
        jmsTemplate.convertAndSend(queue, msg);
    }

    //發送topic類型消息
    @GetMapping("/topic")
    public void sendTopicMsg(String msg){
        jmsTemplate.convertAndSend(topic, msg);
    }
}

7、啟動類

@SpringBootApplication
@EnableJms //啟動消息隊列
public class ActivemqsbApplication {

    public static void main(String[] args) {
        SpringApplication.run(ActivemqsbApplication.class, args);
    }

}

8、啟動程式測試

  • 瀏覽器中輸入http://localhost:8080/activemqsb/queue?msg=hello

    控制台:接收到queue消息:hello

  • 瀏覽器中輸入http://localhost:8080/activemqsb/topic?msg=hello
    控制台:接收到topic消息:hello

參考鏈接: https://www.jianshu.com/p/0d6019f83d5f
https://blog.csdn.net/qq_22200097/article/details/82713261
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 現在新進入web前端開發的人主要分二類,一是畢業就學web前端開發的;二是做了幾年其它工作,然後轉行web前端開發。那麼到底要學習多少技術,才能拿到高薪呢? 01、前端到底需要啥技能? 跨行業零基礎轉行前端的人,到底需要學習多少東西呢? 先看一下他們的弱項,主要體現在以下幾點: 已經參加工作,有生活 ...
  • 在 BasicLayout.jsx 文件中修改 <ProLayout layout="topmenu" className="chenshuai2144" disableMobile rightContentRender={ (rightProps) => <RightContent {...rig ...
  • 效果圖 index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>index</title> <link rel="stylesheet" href="css/ui.css"> <link rel ...
  • json 什麼是JSON "JSON" ( "JavaScript" Object Notation) 是一種輕量級的數據交換格式。它基於 "ECMAScript" 的一個子集。 JSON採用完全獨立於語言的文本格式,但是也使用了類似於C語言家族的習慣(包括 "C" 、C++、 "C " 、 "Ja ...
  • 使用JQuery完成表單的校驗(擴展) 事件: ​ 獲得焦點事件: onfocus ​ 失去焦點事件: onblur ​ 按鍵抬起事件: onkeyup ​ 滑鼠移入: onmouseenter ​ 滑鼠移出: onmouseout JS引入外部文件 : script標簽 需求分析 在用戶提交表單的 ...
  • 使用JQuery完成下列列表左右選擇 Js相關技術 ​ select下拉列表 ​ multiple 允許多選 ​ ondblclick : 雙擊事件 ​ for迴圈遍歷,一邊遍歷一邊移除出現的問題 需求分析 我們的商品通常包含已經有了的, 還有沒有的,現在我們需要有一個頁面用於動態編輯這些商品 步驟 ...
  • 1 #include <Windows.h> 2 #include <iostream> 3 using namespace std; 4 5 int main() 6 { 7 while(true) 8 { 9 if(-32767 == GetAsyncKeyState('A')) //不支持大小 ...
  • 1. OpenCV讀取圖片 1.1 簡述 OpenCV讀取圖片的方法是cv2.imread(),讀取出來圖片的格式是BGR與常規的彩色圖像的格式(RGB)相反,這一點一定要註意。 OpenCV顯示圖片的方法是cv2.imshow(),顯示的格式是BGR。 小生就言於此O(∩_∩)O哈哈~,直接上例子 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...