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

RabbitMQ基礎(chǔ)概念之信道channel詳解

 更新時(shí)間:2023年08月28日 09:43:29   作者:pmdream  
這篇文章主要介紹了RabbitMQ基礎(chǔ)概念之信道channel詳解,信道是生產(chǎn)消費(fèi)者與rabbit通信的渠道,生產(chǎn)者publish或者消費(fèi)者消費(fèi)一個(gè)隊(duì)列都是需要通過信道來通信的,需要的朋友可以參考下

前言:

最近跟著公司一起做項(xiàng)目重構(gòu),也有項(xiàng)目用到了MQ。

其中用到了死信隊(duì)列和延遲隊(duì)列。

先整理一下路由的基礎(chǔ)知識(shí),不能只跟著實(shí)戰(zhàn),堆代碼。

1.channel信道

信道是生產(chǎn)消費(fèi)者與rabbit通信的渠道,生產(chǎn)者publish或者消費(fèi)者消費(fèi)一個(gè)隊(duì)列都是需要通過信道來通信的。

信道是建立在TCP上面的虛擬鏈接,也就是rabbitMQ在一個(gè)TCP上面建立成百上千的信道來達(dá)到多個(gè)線程處理。

注意是一個(gè)TCP 被多個(gè)線程共享,每個(gè)線程對(duì)應(yīng)一個(gè)信道,信道在rabbit都有唯一的ID,保證了信道的私有性,對(duì)應(yīng)上唯一的線程使用。

1.1 為什么RabbitMQ 需要信道,如果直接進(jìn)行TCP通信呢?

上述的描述其實(shí)已經(jīng)很明顯了,因?yàn)門CP可以被多個(gè)線程共享,顯然線程比TCP要省事的多。

TCP的創(chuàng)建開銷很大,創(chuàng)建需要三次握手,銷毀需要四次握手。

如果不使用信道,那么引用程序就會(huì)使用TCP方式進(jìn)行連接到RabbitMQ,因?yàn)镸Q可能每秒會(huì)進(jìn)行成千上萬的鏈接,

總之就是TCP消耗資源

TCP鏈接可以容納無限的信道,不會(huì)有并發(fā)上面的性能瓶頸。

在代碼中并不會(huì)有直觀的能看到信道這個(gè)概念。

因?yàn)榇a中都是用自動(dòng)配置。

@Autowired
RabbitTemplate rabbitTemplate; 

或者使用

@Autowired
private AmqpTemplate template;

都是自動(dòng)隱藏了詳細(xì)的建立連接過程。

但是在使用rabbitmq時(shí)不管是消費(fèi)還是生產(chǎn)都需要?jiǎng)?chuàng)建信道(channel) 和connection(連接)。

連接是連接到RabbitMQ的服務(wù)器~

1.2 連接到RabbitMQ的示意圖

看這個(gè)示意圖的話,我們好像可以直接使用Connection就可以完成信道的工作。

但是因?yàn)榻⑦B接會(huì)很耗費(fèi)性能,這也是有點(diǎn)類似于工廠模式那種吧~用類似nio的做法,連接tcp連接復(fù)用

當(dāng)每個(gè)信道的流量不是很大時(shí),復(fù)用。

但是當(dāng)流量很大的時(shí)候,多個(gè)信道用一個(gè)connection就會(huì)出現(xiàn)性能的瓶頸。

所以使用多個(gè)connection也是合理的,這樣信道可以平攤到每個(gè)connection中。

具體調(diào)節(jié)方式需要在業(yè)務(wù)中進(jìn)行體驗(yàn)。

關(guān)鍵點(diǎn)在于復(fù)用TCP連接

到此這篇關(guān)于RabbitMQ基礎(chǔ)概念之信道channel詳解的文章就介紹到這了,更多相關(guān)RabbitMQ信道channel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java 單例模式(懶漢式與餓漢式)

    java 單例模式(懶漢式與餓漢式)

    這篇文章主要介紹了java 單例模式的相關(guān)資料,這里對(duì)懶漢式與餓漢式都做了實(shí)例介紹,需要的朋友可以參考下
    2017-07-07
  • MAC配置java+jmeter環(huán)境變量過程解析

    MAC配置java+jmeter環(huán)境變量過程解析

    這篇文章主要介紹了MAC配置java+jmeter環(huán)境變量過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java經(jīng)典算法匯總之冒泡排序

    Java經(jīng)典算法匯總之冒泡排序

    冒泡排序基本思想:在要排序的一組數(shù)中,對(duì)當(dāng)前還未排好序的范圍內(nèi)的全部數(shù),自上而下對(duì)相鄰的兩個(gè)數(shù)依次進(jìn)行比較和調(diào)整,讓較大的數(shù)往下沉,較小的往上冒。即:每當(dāng)兩相鄰的數(shù)比較后發(fā)現(xiàn)它們的排序與排序要求相反時(shí),就將它們互換。
    2016-04-04
  • SpringBoot?實(shí)現(xiàn)CAS?Server統(tǒng)一登錄認(rèn)證的詳細(xì)步驟

    SpringBoot?實(shí)現(xiàn)CAS?Server統(tǒng)一登錄認(rèn)證的詳細(xì)步驟

    ??CAS(Central?Authentication?Service)中心授權(quán)服務(wù),是一個(gè)開源項(xiàng)目,目的在于為Web應(yīng)用系統(tǒng)提供一種可靠的單點(diǎn)登錄,這篇文章主要介紹了SpringBoot?實(shí)現(xiàn)CAS?Server統(tǒng)一登錄認(rèn)證,需要的朋友可以參考下
    2024-02-02
  • Java復(fù)合語句的使用方法詳解

    Java復(fù)合語句的使用方法詳解

    這篇文章主要介紹了Java編程中復(fù)合語句,結(jié)合相關(guān)的具體實(shí)例介紹了其用法,需要的朋友可以參考下
    2017-09-09
  • Java線程等待用法實(shí)例分析

    Java線程等待用法實(shí)例分析

    這篇文章主要介紹了Java線程等待用法,結(jié)合實(shí)例形式分析了obj.wait()實(shí)現(xiàn)線程等待相關(guān)原理與操作技巧,需要的朋友可以參考下
    2018-09-09
  • MyBatis中執(zhí)行相關(guān)SQL語句的方法

    MyBatis中執(zhí)行相關(guān)SQL語句的方法

    本文主要介紹了MyBatis中執(zhí)行相關(guān)SQL語句的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • Spring?Retry實(shí)現(xiàn)重試機(jī)制的示例詳解

    Spring?Retry實(shí)現(xiàn)重試機(jī)制的示例詳解

    這篇文章主要為大家詳細(xì)介紹了Spring-Retry的用法以及實(shí)現(xiàn)原理是怎么樣的,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以了解一下
    2023-07-07
  • RocketMQ發(fā)送事務(wù)消息詳解

    RocketMQ發(fā)送事務(wù)消息詳解

    這篇文章主要介紹了RocketMQ發(fā)送事務(wù)消息詳解,RocketMQ分布式事務(wù)消息不僅可以實(shí)現(xiàn)應(yīng)用之間的解耦,又能保證數(shù)據(jù)的最終一致性,傳統(tǒng)的大事務(wù)可以被拆分為小事務(wù),不僅能提升效率,還不會(huì)因?yàn)槟骋粋€(gè)關(guān)聯(lián)應(yīng)用的不可用導(dǎo)致整體回滾,需要的朋友可以參考下
    2023-09-09
  • 使用Spring Boot集成FastDFS的示例代碼

    使用Spring Boot集成FastDFS的示例代碼

    本篇文章主要介紹了使用Spring Boot集成FastDFS的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-02-02

最新評(píng)論