消息隊(duì)列可以解決那些問題?

在單體應(yīng)用中获枝,我們常常使用簡單的數(shù)據(jù)結(jié)構(gòu)——隊(duì)列蠢正,來解決一些實(shí)際問題,比如生產(chǎn)者消費(fèi)者模式使用隊(duì)列作為中間傳輸省店。在復(fù)雜的分布式環(huán)境中嚣崭,簡單隊(duì)列是無法解決分布式環(huán)境一定存在的問題,比如應(yīng)用之間的通信萨西、消息持久化有鹿、消息傳輸控制等等問題。消息隊(duì)列又能解決那些問題呢谎脯?

1.異步處理

舉個例子:在商城系統(tǒng)中葱跋,訂單系統(tǒng)下單成功后,需要一些后處理源梭,比如扣減庫存娱俺、統(tǒng)計(jì)銷售數(shù)量、短信通知废麻、消息推送荠卷、優(yōu)惠卷占用等等。如果所有這些操作都是同步處理烛愧,那下單耗時(shí)非常嚴(yán)重油宜,影響用戶體驗(yàn)×耍可以利用消息隊(duì)列將這些同步操作改為向各個系統(tǒng)發(fā)送消息慎冤,接口直接返回訂單信息。

2. 流量控制(削峰填谷)

我們的應(yīng)用處理請求能力是有限沧卢,在一些存在海量請求的場景中蚁堤,比如秒殺、搶購等等但狭。如果直接處理這海量請求披诗,可能我們的應(yīng)用早掛掉了。這時(shí)候可以把這些請求丟進(jìn)消息隊(duì)列中立磁,下游系統(tǒng)以自己的處理能力消費(fèi)這些消息呈队,起到了削峰填谷的作用。

3. 應(yīng)用間解耦

下游應(yīng)用依賴上游應(yīng)用唱歧,如果在代碼每個地方都依賴掂咒,這樣維護(hù)應(yīng)用之間的依賴關(guān)系非常頭疼。比如電商系統(tǒng)中常見的訂單狀態(tài)迈喉,有許多下游系統(tǒng)依賴訂單系統(tǒng)绍刮,訂單狀態(tài)可能是待付款、待發(fā)貨挨摸、待收貨等等孩革。如果訂單狀態(tài)每次變更都在訂單系統(tǒng)中調(diào)用其他系統(tǒng),那么維護(hù)訂單系統(tǒng)的人肯定還在加班(哈哈)得运。如果所有的訂單狀態(tài)變更狀態(tài)處理都在訂單系統(tǒng)膝蜈,那么應(yīng)用之間的耦合度太高。這時(shí)候可以使用消息隊(duì)列這把利器熔掺,可以利用消息隊(duì)列中主題-訂閱模式饱搏,訂單狀態(tài)發(fā)生變化只需要發(fā)送消息,而需要處理訂單狀態(tài)變更的系統(tǒng)只需訂閱訂單狀態(tài)變更的Topic置逻。這樣訂單系統(tǒng)與其他系統(tǒng)就不是強(qiáng)耦合推沸。

4. 總結(jié)

消息隊(duì)列的典型應(yīng)用場景:異步處理、流量控制券坞、應(yīng)用間解耦鬓催。除此之外消息對了還可以:

  • 作為發(fā)布 / 訂閱系統(tǒng)實(shí)現(xiàn)一個微服務(wù)級系統(tǒng)間的觀察者模式;
  • 連接流計(jì)算任務(wù)和數(shù)據(jù)
  • 將消息廣播給大量消費(fèi)者
    消息隊(duì)列不是銀彈恨锚,引入消息隊(duì)列也會存在一些問題:
  • 消息延遲
  • 數(shù)據(jù)可能不一致
  • 增加系統(tǒng)復(fù)雜度
    所以我們一定要根據(jù)自身的業(yè)務(wù)特點(diǎn)選擇是否使用消息隊(duì)列宇驾。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市猴伶,隨后出現(xiàn)的幾起案子课舍,更是在濱河造成了極大的恐慌,老刑警劉巖他挎,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件筝尾,死亡現(xiàn)場離奇詭異,居然都是意外死亡雇盖,警方通過查閱死者的電腦和手機(jī)忿等,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來崔挖,“玉大人贸街,你說我怎么就攤上這事±晗啵” “怎么了薛匪?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長脓鹃。 經(jīng)常有香客問我逸尖,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任娇跟,我火速辦了婚禮岩齿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘苞俘。我一直安慰自己盹沈,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布吃谣。 她就那樣靜靜地躺著乞封,像睡著了一般。 火紅的嫁衣襯著肌膚如雪岗憋。 梳的紋絲不亂的頭發(fā)上肃晚,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天,我揣著相機(jī)與錄音仔戈,去河邊找鬼关串。 笑死,一個胖子當(dāng)著我的面吹牛杂穷,可吹牛的內(nèi)容都是我干的悍缠。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼耐量,長吁一口氣:“原來是場噩夢啊……” “哼飞蚓!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起廊蜒,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤趴拧,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后山叮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體著榴,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年屁倔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了脑又。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡锐借,死狀恐怖问麸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钞翔,我是刑警寧澤严卖,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站布轿,受9級特大地震影響哮笆,放射性物質(zhì)發(fā)生泄漏来颤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一稠肘、第九天 我趴在偏房一處隱蔽的房頂上張望福铅。 院中可真熱鬧,春花似錦启具、人聲如沸本讥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至色查,卻和暖如春薯演,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背秧了。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工跨扮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人验毡。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓衡创,卻偏偏與公主長得像,于是被迫代替她去往敵國和親晶通。 傳聞我的和親對象是個殘疾皇子璃氢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評論 2 354