Rabbitmq---消息隊列

来源:https://www.cnblogs.com/nanlinghan/archive/2018/11/14/9960314.html
-Advertisement-
Play Games

一 . MQ:message queue 消息隊列的作用: 1 通信解耦 2 高峰限流 原理分析: 一開始,認證系統是強耦合的,A系統傳遞認證系統消息接收計算結果的過程中 1 傳給認證系統 2 認證系統計算 3 返回計算結果 4 讀取A系統邏輯 只要當前計算沒有完成,對於認證系統來講消耗線程資源.並 ...


一 . MQ:message queue

  消息隊列的作用:   1 通信解耦   2 高峰限流

原理分析:

一開始,認證系統是強耦合的,A系統傳遞認證系統消息接收計算結果的過程中

  1 傳給認證系統

  2 認證系統計算

  3 返回計算結果

  4 讀取A系統邏輯

只要當前計算沒有完成,對於認證系統來講消耗線程資源.並存在強耦合現象

有了消息隊列,每一次連接不管是生成消息還是消費消息,都有各自的邏輯與其他邏輯無關--通信解耦

 

  通信強耦合的情況下高峰訪問拒絕,達到了高峰限流的效果

二 . Rabbitmq

  1 rabbitmq的結構(組件)

    外部: 生產者和消費者

    生產者:對於消息來講,生成消息客戶端是生產者

    消費者:消費消息執行消費後的邏輯的客戶端是消費者

  客戶端可以使用各種其他技術或者語言 都不是rabbitmq自身的技術

  2 rabbitmq內部組件

  connection:基於底層通信邏輯的長連接

  channel:基於長連接創建的;可以在一次長連接的基礎上多次頻繁的創建和銷毀,占用資源非常少

  交換機Exchange   優點:併發能力高 併發穩定

    客戶端連接發送消息,多種情況都需要併發的發送,如果從客戶端執行併發的發送邏輯,rabbitmq的併發能力就限制在了客戶端

    exchange基於erlang語言開發的(併發,可控制線程)

  queue:rabbitmq中的隊列,根據不同的情況隊列可以完成不同的工作

  使用場景:在項目中,將一些無需即時返回且耗時的操作提取出來,進行了非同步處理,而這種非同步處理的方式大大的節省了伺服器的請求響應時間,從而提高了系統的吞吐量。

三 . rabbitmq的五種工作模式

  1 簡單模式

  

  1 )一個生產者將消息交給預設的交換機(AMQP default)

  2 )交換機獲取消息後交給綁定的這個生產者的隊列(其中關係是通過隊列名稱完成的)

  3 )監聽當前隊列的消費者獲取消息,執行消費邏輯

    應用場景:簡訊聊天

  2 工作模式(資源爭搶)

  

  1 )生產者將消息交給交換機

  2 )交換機交給綁定的隊列

  3 )隊列由多個消費者同時監聽,只有其中一個能獲取者一條消息,形成了資源的爭搶,誰的資源空閑大,爭搶到的可能越大

  3 發佈訂閱(publish/fanout)

  1 )生產者扔給交換機消息
  2 )交換機根據自身的類型(fanout)將會把所有消息複製同步到所有與其綁定的隊列
  3 )每個隊列可以有一個消費者,接收消息進行消費邏輯

  4 路由模式(routing/dircet)

  

  1 )生產者還是將消息發送給交換機,消息攜帶具體的路由key(routingKey)

  2 )交換機類型direct,將接受到消息中的routingKey與之綁定隊列的routingKey比對

  3 )消費者監聽一個隊列,獲取消息,執行消費邏輯.

  5 topic主題模式

  

  1 )生產端發送消息,消息攜帶具體的路由key
  2 )交換機的類型topic
  3 )隊列綁定交換機不在使用具體的路由key而是一個範圍值

 與路由模式的區別:路由模式中的queue綁定攜帶的具體的key值,路由細化劃分,topic主題模式queue攜帶的key是一個範圍的匹配,某一類消息的獲取

   

四 . rabbitmq的安裝及虛擬機和用戶名的創建

  https://www.cnblogs.com/nanlinghan/p/9960361.html

五 . springboot整合rabbitmq

  整合思路:1 )配置信息 2 )配置類 (明確初始化對象,初始化一個工廠,就從工廠獲取連接;生產端邏輯實現簡單;) 3 )二次封裝

  springboot
      自動配置:掃描同名,下級包
           根據依賴的文件自動配置需要的內容(一旦依賴了jdbc,不配置datasource就報錯)
      springboot就會根據依賴的amqp自動創建連接消息隊列的內部connection,封裝一個對外調用的對象rabbitTemplate模板對象;做生產邏輯
      利用底層連接,實現非同步非阻塞監聽,只需要在方法上使用註解,就可以將監聽內容傳遞給方法的參數;

1 添加依賴
    <starter-amqp>簡化依賴
      groupId在maven庫是一個具有結構的文件夾
      artifactId是一整個文件夾
      version是一個文件夾
       org\springframework\boot\spring-boot-starter-amqp
     <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>

2 配置文件(application.properties)

      spring.rabbitmq.host=10.9.100.26
      spring.rabbitmq.port=5672
      spring.rabbitmq.username=easymall
      spring.rabbitmq.password=123456
   spring.rabbitmq.virtualHost=/easymall

3 配置文件中聲明對象

      內部完成各種連接channel等的封裝
      聲明需要的隊列和交換機
     配置類中完成這種聲明,並且交換機,隊列的對象由框架維護,何時調用由業務邏輯決定;

 1 package com.jt.config;
 2 import org.springframework.amqp.core.Binding;
 3 import org.springframework.amqp.core.BindingBuilder;
 4 import org.springframework.amqp.core.DirectExchange;
 5 import org.springframework.amqp.core.Queue;
 6 import org.springframework.context.annotation.Bean;
 7 import org.springframework.context.annotation.Configuration;
 8 @Configuration
 9 public class RabbitmqConfig {
10     //路由模式做案例
11     //準備2個queue,1個路由交換機
12     //聲明2個隊列
13     @Bean 
14     public Queue queue01(){
15         //org.springframework.amqp.core.
16         return new Queue("springboot-q1", false);
17     }  
18     @Bean 
19     public Queue queue02(){
20         //org.springframework.amqp.core.
21         return new Queue("springboot-q2", false);
22     } 
23     @Bean//聲明交換機
24     public DirectExchange ex(){
25         return new DirectExchange("springboot-ex");
26     }
27     //聲明綁定關係
28     @Bean
29     public Binding bind01(){
30         return BindingBuilder.
31                 bind(queue01()).to(ex()).with("item.add");
32     }
33     @Bean
34     public Binding bind02(){
35         return BindingBuilder.
36                 bind(queue02()).to(ex()).with("item.update");}}

4 編寫生成者代碼

      編寫到一個controller中,接收訪問的參數,利用參數作為消息發送到交換機攜帶路由key

 1 package com.jt.controller;
 2 
 3 import org.springframework.amqp.rabbit.core.RabbitTemplate;
 4 import org.springframework.beans.factory.annotation.Autowired;
 5 import org.springframework.stereotype.Controller;
 6 import org.springframework.web.bind.annotation.RequestMapping;
 7 import org.springframework.web.bind.annotation.ResponseBody;
 8 
 9 @Controller
10 public class MsgController {
11     @Autowired
12     private RabbitTemplate rabbit;
13     /*
14      * 接收消息msg
15      */
16     @RequestMapping("msg")
17     @ResponseBody
18     public String sendMsg(String msg,String routingKey){
19         //註入自動配置的rabbitTemplate對象發送消息
20         rabbit.convertAndSend("springboot-ex", routingKey, msg);
21         return "success";
22     }
23 }

5 消費端

  2個消費者,監聽2個隊列,發送的不同路由key會在不同的消費端完成消費邏輯

 1 package com.jt.component;
 2 
 3 import org.springframework.amqp.rabbit.annotation.RabbitListener;
 4 import org.springframework.stereotype.Component;
 5 @Component
 6 public class ConsumerCon {
 7     //實現消費邏輯,需要完成非同步監聽
 8     //監聽註解會綁定隊列的消費者和當前的方法,一旦消費者獲取消息,會把消息內容傳遞給
 9     //自定義的方法參數msg
10     @RabbitListener(queues="springboot-q1")
11     public void process01(String msg){
12         System.out.println("消費者1接收商品新增:"+msg);
13     }
14     
15     @RabbitListener(queues="springboot-q2")
16     public void process02(String msg){
17         System.out.println("消費者2接收到商品更新:"+msg);
18     }
19 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 #!/bin/bash 2 # coding: utf-8 3 # Copyright (c) 2018 4 set -e #返回值為0時,退出腳本 5 echo "1. 備份yum" 6 { 7 for i in /etc/yum.repos.d/*.repo;do cp $i ${i%.re ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "[amc" ](https://cloud.tencent.com/developer/user/1024461?fromSource=waitui)發表於 "雲+社區專欄" 在 C 語言的動態申請記憶體技術中,相比起 /` ...
  • Linux下find命令在目錄結構中搜索文件,並執行指定的操作。Linux下find命令提供了相當多的查找條件,功能很強大。由於find具有強大的功能,所以它的選項也很多,其中大部分選項都值得我們花時間來瞭解一下。即使系統中含有網路文件系統( NFS),find命令在該文件系統中同樣有效,只你具有相 ...
  • 1 #!/bin/bash 2 # coding: utf-8 3 # Copyright (c) 2018 4 5 set -e #返回值為非0時,退出腳本 6 7 echo "0. 系統的一些配置" 8 setenforce 0 || true 9 systemctl stop iptables... ...
  • 我一直比較推薦一些Linux新手使用Deepin Linux,因為我認為這種儘量的follow Windows的系統至少對於新手來說是比較的友好的,而且預裝了QQ 火狐瀏覽器中文版,甚至還移植了像360安全瀏覽器這些,自帶的應用商店等等,去掉了很多至少對於一般的Linux用戶,初學者這些用不到的組件 ...
  • 一、Tomcat安裝 1.下載jdk,Tomcat,解壓到/usr/local/ 2.配置jdk環境:# vim /etc/profile export JAVA_HOME=/usr/local/jdk1.8.0_171 export PATH=$JAVA_HOME/bin:$PATH export ...
  • Linux使用MySQL Yum存儲庫上安裝MySQL 5.6,適用於Oracle Linux,Red Hat Enterprise Linux和CentOS系統。 一、全新安裝MySQL 1、添加MySQL Yum存儲庫 將MySQL Yum存儲庫添加到系統的存儲庫列表中。這是一次性操作,可以通過 ...
  • --資料庫操作前的準備-- 創建資料庫-- create database python_test_1 charset=utf8; -- 使用資料庫-- use python_test_1; -- students表-- create table students(-- id int unsigne ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...