rabbitMQ

MQ優(yōu)勢(shì):

應(yīng)用解耦:提高系統(tǒng)容錯(cuò)性和可維護(hù)性

異步提速:提升用戶體驗(yàn)和系統(tǒng)吞吐量

削峰填谷:提高系統(tǒng)穩(wěn)定性

劣勢(shì)

使用條件

①生產(chǎn)者不需要從消費(fèi)者處獲得反饋胡岔。引入消息隊(duì)列之前的直接調(diào)用,其接口的返回值應(yīng)該為空,這才讓明明下層的動(dòng)作還沒做迫筑,上層卻當(dāng)成動(dòng)作做完了繼續(xù)往后走村刨,即所謂異步成為了可能十减。

②容許短暫的不一致性栈幸。

③確實(shí)是用了有效果。即解耦帮辟、提速速址、削峰這些方面的收益,超過加入MQ由驹,管理MQ這些成本芍锚。

概念

Broker:接收和分發(fā)消息的應(yīng)用,RabbitMQ Server就是 Message Broker蔓榄。

Virtual host:出于多租戶和安全因素設(shè)計(jì)的并炮,把 AMQP 的基本組件劃分到一個(gè)虛擬的分組中,類似于網(wǎng)絡(luò)中的 namespace 概念甥郑。當(dāng)多個(gè)不同的用戶使用同一個(gè) RabbitMQ server 提供的服務(wù)時(shí)渣触,可以劃分出多個(gè)vhost,每個(gè)用戶在自己的 vhost 創(chuàng)建 exchange/queue 等壹若。

Connection:publisher/consumer 和 broker 之間的 TCP 連接。

Channel:如果每一次訪問 RabbitMQ 都建立一個(gè) Connection皂冰,在消息量大的時(shí)候建立 TCP Connection的開銷將是巨大的店展,效率也較低。Channel 是在 connection 內(nèi)部建立的邏輯連接秃流,如果應(yīng)用程序支持多線程赂蕴,通常每個(gè)thread創(chuàng)建單獨(dú)的 channel 進(jìn)行通訊,AMQP method 包含了channel id 幫助客戶端和message broker 識(shí)別 channel舶胀,所以 channel 之間是完全隔離的概说。Channel 作為輕量級(jí)的 Connection 極大減少了操作系統(tǒng)建立 TCP connection 的開銷碧注。

Exchange:message 到達(dá) broker 的第一站,根據(jù)分發(fā)規(guī)則糖赔,匹配查詢表中的 routing key萍丐,分發(fā)消息到queue 中去。常用的類型有:direct (point-to-point), topic (publish-subscribe) and fanout (multicast)放典。

Queue:消息最終被送到這里等待 consumer 取走逝变。

Binding:exchange 和 queue 之間的虛擬連接,binding 中可以包含 routing key奋构。Binding 信息被保存到 exchange 中的查詢表中壳影,用于 message 的分發(fā)依據(jù)。

簡(jiǎn)介

RabbitMQ 提供了 6 種工作模式:簡(jiǎn)單模式弥臼、work queues宴咧、Publish/Subscribe 發(fā)布與訂閱模式、Routing 路由模式径缅、Topics 主題模式掺栅、RPC 遠(yuǎn)程調(diào)用模式。

官網(wǎng)對(duì)應(yīng)模式介紹:https://www.rabbitmq.com/getstarted.html

JMS

JMS 即 Java 消息服務(wù)(JavaMessage Service)應(yīng)用程序接口芥驳,是一個(gè) Java 平臺(tái)中關(guān)于面向消息中間件的API.

JMS 是 JavaEE 規(guī)范中的一種柿冲,類比JDBC.

很多消息中間件都實(shí)現(xiàn)了JMS規(guī)范,例如:ActiveMQ兆旬。RabbitMQ 官方?jīng)]有提供 JMS 的實(shí)現(xiàn)包假抄,但是開源社區(qū)有.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市丽猬,隨后出現(xiàn)的幾起案子宿饱,更是在濱河造成了極大的恐慌,老刑警劉巖脚祟,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谬以,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡由桌,警方通過查閱死者的電腦和手機(jī)为黎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來行您,“玉大人铭乾,你說我怎么就攤上這事⊥扪” “怎么了炕檩?”我有些...
    開封第一講書人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長捌斧。 經(jīng)常有香客問我笛质,道長泉沾,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任妇押,我火速辦了婚禮跷究,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘舆吮。我一直安慰自己揭朝,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開白布色冀。 她就那樣靜靜地躺著潭袱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪锋恬。 梳的紋絲不亂的頭發(fā)上屯换,一...
    開封第一講書人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音与学,去河邊找鬼彤悔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛索守,可吹牛的內(nèi)容都是我干的晕窑。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼卵佛,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼杨赤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起截汪,我...
    開封第一講書人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤疾牲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后衙解,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體阳柔,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年蚓峦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了舌剂。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡暑椰,死狀恐怖霍转,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情干茉,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布很泊,位于F島的核電站角虫,受9級(jí)特大地震影響沾谓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜戳鹅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一均驶、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧枫虏,春花似錦妇穴、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至死讹,卻和暖如春瞒滴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赞警。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來泰國打工妓忍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人愧旦。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓世剖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親笤虫。 傳聞我的和親對(duì)象是個(gè)殘疾皇子旁瘫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 消息隊(duì)列之 RabbitMQ 關(guān)于消息隊(duì)列,從前年開始斷斷續(xù)續(xù)看了些資料耕皮,想寫很久了境蜕,但一直沒騰出空,近來分別碰到...
    沒想好像閱讀 234評(píng)論 1 1
  • 概述 RabbitMQ是目前非常熱門的一款消息中間件凌停,不管是互聯(lián)網(wǎng)行業(yè)還是傳統(tǒng)行業(yè)都在大量地使用 粱年。 Rabbit...
    Tian_Peng閱讀 1,664評(píng)論 1 4
  • 1 頁面發(fā)布 1.1 需求分析 業(yè)務(wù)流程如下: 1、管理員進(jìn)入管理界面點(diǎn)擊“頁面發(fā)布”罚拟,前端請(qǐng)求cms頁面發(fā)布接口...
    lww文閱讀 237評(píng)論 0 0
  • 0. 前言 什么是消息中間件 安裝RabbitMQ 編寫RabbitMQ的入門程序 RabbitMQ的5種模式特征...
    abboo閱讀 718評(píng)論 0 1
  • 前言 消息隊(duì)列在現(xiàn)今數(shù)據(jù)量超大台诗,并發(fā)量超高的系統(tǒng)中是十分常用的。本文將會(huì)對(duì)現(xiàn)時(shí)最常用到的幾款消息隊(duì)列框架 Acti...
    AI喬治閱讀 744評(píng)論 0 7