消息隊列應(yīng)用場景

消息隊列在企業(yè)中的應(yīng)用

消息服務(wù)蕉扮,是企業(yè)級服務(wù)體系中比較重要的一個組件整胃,它必須具有低延時、高可靠喳钟、可擴展等特性屁使,為業(yè)務(wù)提供基礎(chǔ)建設(shè)。
應(yīng)用消息服務(wù)的目的在于:異步奔则、削峰填谷蛮寂、解耦應(yīng)用。
最常用的MQ類型有:kafka易茬、rocketmq酬蹋、activemq、rabbitmq抽莱、zeromq范抓。

異步

在企業(yè)服務(wù)架構(gòu)中,自頂向下食铐,調(diào)用一個產(chǎn)品或者接口匕垫,需要經(jīng)過多層服務(wù)調(diào)用,有些服務(wù)的耗時長會使得整個應(yīng)用都被拖慢璃岳,因此年缎,我們可以把耗時操作異步化。

比如短信系統(tǒng)铃慷,統(tǒng)計發(fā)送列表并創(chuàng)建發(fā)送任務(wù)单芜,在統(tǒng)計的這個功能上耗時會比較長,所以我們可以設(shè)計一個任務(wù)機集群犁柜,消費消息隊列提供的統(tǒng)計參數(shù)洲鸠,然后將任務(wù)記錄到數(shù)據(jù)庫中,再由另一個流程查詢結(jié)果馋缅。


短信系統(tǒng).png

再比如扒腕,申請簽署文件這個業(yè)務(wù),前端發(fā)起簽署后生成簽署文件并展示給客戶簽署萤悴,在文檔生成這一塊就比較耗時瘾腰,所以我們采用了向簽署系統(tǒng)發(fā)送關(guān)鍵參數(shù)到消息隊列,并且流程異步化的操作覆履,在頁面上降低客戶對實時的預(yù)期蹋盆,流程上采用異步業(yè)務(wù)的方式。


簽署系統(tǒng).png

還有硝全,對于數(shù)據(jù)收集的應(yīng)用栖雾,我們也采用了消息隊列對關(guān)鍵數(shù)據(jù)收集的功能,將業(yè)務(wù)產(chǎn)生的關(guān)鍵參數(shù)發(fā)送到消息隊列中伟众,然后由收集線程統(tǒng)一收集入庫析藕,這樣對業(yè)務(wù)來說既不占用業(yè)務(wù)的延時也能進行故障隔離,倘若消息隊列出來問題凳厢,我們的業(yè)務(wù)也不至于收到中斷的影響账胧,因為采用了線程池解耦了業(yè)務(wù)流程。


數(shù)據(jù)收集.png

削峰填谷

另一個應(yīng)用場景数初,就是對大量的寫操作進行cache的一種思想找爱。互聯(lián)網(wǎng)項目中很多都是讀請求泡孩,但秒殺這種場景就會有很多寫請求车摄。秒殺場景下,比如100件商品是理論上只會update100次仑鸥,但是如果商品熱度很高吮播,就會有瞬間執(zhí)行update大大超過100次的情況,所以我們的方案是不能從頁面上直接透到數(shù)據(jù)庫的眼俊。
采用消息隊列緩存秒殺請求意狠,也是一種方案。


削峰填谷.png

這樣消費服務(wù)以恒定的速率處理到數(shù)據(jù)庫中疮胖,就不會因為瞬時大流量而導(dǎo)致數(shù)據(jù)庫掛了环戈,在這個時候消息隊列的可靠性就凸顯了闷板,不能因為幾十萬的消息崩潰,也不能丟失太多的消息院塞。

服務(wù)解耦

服務(wù)解耦的作用遮晚,和異步有點類似,只不過異步是對于流程上的視角而言拦止,服務(wù)解耦則是服務(wù)視角上的县遣。
比如短信系統(tǒng),原本一體化的應(yīng)用是短信和統(tǒng)計在一起的汹族,進行微服務(wù)拆分之后萧求,就會使用消息隊列作為交互,把一些rpc調(diào)用的場景直接設(shè)計為服務(wù)間通過消息消費的方式顶瞒,就可以不在服務(wù)中大量寫入調(diào)用代碼夸政。
我們在一個身份校驗系統(tǒng)中采用過,一個身份校驗系統(tǒng)有一個流程id搁拙,每次這個流程id完成身份校驗之后秒梳,就會在消息隊列中一個virtual topic中廣播一條消息。需要訂閱的系統(tǒng)箕速,只需要消費這個virtual topic就好了酪碘,不需要再對接系統(tǒng)的結(jié)果查詢之類的接口,這樣就可以做到服務(wù)的解耦了盐茎。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末兴垦,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子字柠,更是在濱河造成了極大的恐慌探越,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件窑业,死亡現(xiàn)場離奇詭異钦幔,居然都是意外死亡,警方通過查閱死者的電腦和手機常柄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門鲤氢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人西潘,你說我怎么就攤上這事卷玉。” “怎么了喷市?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵相种,是天一觀的道長。 經(jīng)常有香客問我品姓,道長寝并,這世上最難降的妖魔是什么箫措? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮衬潦,結(jié)果婚禮上蒂破,老公的妹妹穿的比我還像新娘。我一直安慰自己别渔,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布惧互。 她就那樣靜靜地躺著哎媚,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喊儡。 梳的紋絲不亂的頭發(fā)上拨与,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機與錄音艾猜,去河邊找鬼买喧。 笑死,一個胖子當(dāng)著我的面吹牛匆赃,可吹牛的內(nèi)容都是我干的淤毛。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼算柳,長吁一口氣:“原來是場噩夢啊……” “哼低淡!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起瞬项,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤蔗蹋,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后囱淋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體猪杭,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年妥衣,在試婚紗的時候發(fā)現(xiàn)自己被綠了皂吮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡称鳞,死狀恐怖涮较,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情冈止,我是刑警寧澤狂票,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站熙暴,受9級特大地震影響闺属,放射性物質(zhì)發(fā)生泄漏慌盯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一掂器、第九天 我趴在偏房一處隱蔽的房頂上張望亚皂。 院中可真熱鬧,春花似錦国瓮、人聲如沸灭必。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽禁漓。三九已至,卻和暖如春孵睬,著一層夾襖步出監(jiān)牢的瞬間播歼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工掰读, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留秘狞,地道東北人。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓蹈集,卻偏偏與公主長得像烁试,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子拢肆,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,876評論 2 361

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