RabbitMQ基礎(chǔ)概念之信道channel詳解
前言:
最近跟著公司一起做項(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)文章
MAC配置java+jmeter環(huán)境變量過程解析
這篇文章主要介紹了MAC配置java+jmeter環(huán)境變量過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09SpringBoot?實(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-02MyBatis中執(zhí)行相關(guān)SQL語句的方法
本文主要介紹了MyBatis中執(zhí)行相關(guān)SQL語句的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08Spring?Retry實(shí)現(xiàn)重試機(jī)制的示例詳解
這篇文章主要為大家詳細(xì)介紹了Spring-Retry的用法以及實(shí)現(xiàn)原理是怎么樣的,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以了解一下2023-07-07