精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

敢在簡歷上寫消息隊列,這幾個問題必須拿下!

開發 前端
引入 MQ 消息中間件實現系統解耦,會影響系統之間數據傳輸的一致性。 在分布式系統中,如果兩個節點之間存在數據同步,就會帶來數據一致性的問題。

面試官在面試候選人時,如果發現候選人的簡歷中寫了在項目中使用了 MQ 技術(如 Kafka、RabbitMQ、RocketMQ),基本都會拋出一個問題:在使用 MQ 的時候,怎么確保消息 100% 不丟失?

這個問題在實際工作中很常見,既能考察候選者對于 MQ 中間件技術的掌握程度,又能很好地區分候選人的能力水平。接下來,我們就從這個問題出發,探討你應該掌握的基礎知識和答題思路,以及延伸的面試考點。

案例背景

以京東系統為例,用戶在購買商品時,通常會選擇用京豆抵扣一部分的金額,在這個過程中,交易服務和京豆服務通過 MQ 消息隊列進行通信。在下單時,交易服務發送“扣減賬戶 X 100 個京豆”的消息給 MQ 消息隊列,而京豆服務則在消費端消費這條命令,實現真正的扣減操作。

圖片圖片

那在這個過程中你會遇到什么問題呢?

案例分析

要知道,在互聯網面試中,引入 MQ 消息中間件最直接的目的是:做系統解耦合流量控制,追其根源還是為了解決互聯網系統的高可用和高性能問題。

  • 系統解耦:用 MQ 消息隊列,可以隔離系統上下游環境變化帶來的不穩定因素,比如京豆服務的系統需求無論如何變化,交易服務不用做任何改變,即使當京豆服務出現故障,主交易流程也可以將京豆服務降級,實現交易服務和京豆服務的解耦,做到了系統的高可用。
  • 流量控制:遇到秒殺等流量突增的場景,通過 MQ 還可以實現流量的“削峰填谷”的作用,可以根據下游的處理能力自動調節流量。

不過引入 MQ 雖然實現了系統解耦合流量控制,也會帶來其他問題。

引入 MQ 消息中間件實現系統解耦,會影響系統之間數據傳輸的一致性。 在分布式系統中,如果兩個節點之間存在數據同步,就會帶來數據一致性的問題。同理,在這一講你要解決的就是:消息生產端和消息消費端的消息數據一致性問題(也就是如何確保消息不丟失)。

而引入 MQ 消息中間件解決流量控制, 會使消費端處理能力不足從而導致消息積壓,這也是你要解決的問題。

所以你能發現,問題與問題之間往往是環環相扣的,面試官會借機考察你解決問題思路的連貫性和知識體系的掌握程度。

那面對“在使用 MQ 消息隊列時,如何確保消息不丟失”這個問題時,你要怎么回答呢?首先,你要分析其中有幾個考點,比如:

  • 如何知道有消息丟失?
  • 哪些環節可能丟消息?
  • 如何確保消息不丟失?

候選人在回答時,要先讓面試官知道你的分析思路,然后再提供解決方案:網絡中的數據傳輸不可靠,想要解決如何不丟消息的問題,首先要知道哪些環節可能丟消息,以及我們如何知道消息是否丟失了,最后才是解決方案(而不是上來就直接說自己的解決方案)。就好比“架構設計”“架構”體現了架構師的思考過程,而“設計”才是最后的解決方案,兩者缺一不可。

案例解答

我們首先來看消息丟失的環節,一條消息從生產到消費完成這個過程,可以劃分三個階段,分別為消息生產階段,消息存儲階段和消息消費階段。

圖片圖片

  • 消息生產階段: 從消息被生產出來,然后提交給 MQ 的過程中,只要能正常收到 MQ Broker 的 ack 確認響應,就表示發送成功,所以只要處理好返回值和異常,這個階段是不會出現消息丟失的。
  • 消息存儲階段: 這個階段一般會直接交給 MQ 消息中間件來保證,但是你要了解它的原理,比如 Broker 會做副本,保證一條消息至少同步兩個節點再返回 ack。
  • 消息消費階段: 消費端從 Broker 上拉取消息,只要消費端在收到消息后,不立即發送消費確認給 Broker,而是等到執行完業務邏輯后,再發送消費確認,也能保證消息的不丟失。

方案看似萬無一失,每個階段都能保證消息的不丟失,但在分布式系統中,故障不可避免,作為消息生產端,你并不能保證 MQ 是不是弄丟了你的消息,消費者是否消費了你的消息,所以,本著 Design for Failure 的設計原則,你還是需要一種機制,來 Check 消息是否丟失了。

緊接著,你還可以向面試官闡述怎么進行消息檢測? 總體方案解決思路為:在消息生產端,給每個發出的消息都指定一個全局唯一 ID,或者附加一個連續遞增的版本號,然后在消費端做對應的版本校驗。

具體怎么落地實現呢?你可以利用攔截器機制。 在生產端發送消息之前,通過攔截器將消息版本號注入消息中(版本號可以采用連續遞增的 ID 生成,也可以通過分布式全局唯一 ID生成)。然后在消費端收到消息后,再通過攔截器檢測版本號的連續性或消費狀態,這樣實現的好處是消息檢測的代碼不會侵入到業務代碼中,可以通過單獨的任務來定位丟失的消息,做進一步的排查。

這里需要你注意:如果同時存在多個消息生產端和消息消費端,通過版本號遞增的方式就很難實現了,因為不能保證版本號的唯一性,此時只能通過全局唯一 ID 的方案來進行消息檢測,具體的實現原理和版本號遞增的方式一致。

現在,你已經知道了哪些環節(消息存儲階段、消息消費階段)可能會出問題,并有了如何檢測消息丟失的方案,然后就要給出解決防止消息丟失的設計方案。

回答完“如何確保消息不會丟失?” 之后,面試官通常會追問“怎么解決消息被重復消費的問題? ”

比如:在消息消費的過程中,如果出現失敗的情況,通過補償的機制發送方會執行重試,重試的過程就有可能產生重復的消息,那么如何解決這個問題?

這個問題其實可以換一種說法,就是如何解決消費端冪等性問題(冪等性,就是一條命令,任意多次執行所產生的影響均與一次執行的影響相同),只要消費端具備了冪等性,那么重復消費消息的問題也就解決了。

我們還是來看扣減京豆的例子,將賬戶 X 的金豆個數扣減 100 個,在這個例子中,我們可以通過改造業務邏輯,讓它具備冪等性。

圖片圖片

最簡單的實現方案,就是在數據庫中建一張消息日志表, 這個表有兩個字段:消息 ID 和消息執行狀態。這樣,我們消費消息的邏輯可以變為:在消息日志表中增加一條消息記錄,然后再根據消息記錄,異步操作更新用戶京豆余額。

因為我們每次都會在插入之前檢查是否消息已存在,所以就不會出現一條消息被執行多次的情況,這樣就實現了一個冪等的操作。當然,基于這個思路,不僅可以使用關系型數據庫,也可以通過 Redis 來代替數據庫實現唯一約束的方案。

在這里我多說一句,想要解決“消息丟失”和“消息重復消費”的問題,有一個前提條件就是要實現一個全局唯一 ID 生成的技術方案。這也是面試官喜歡考察的問題,你也要掌握。

在分布式系統中,全局唯一 ID 生成的實現方法有數據庫自增主鍵、UUID、Redis,Twitter-Snowflake 算法,我總結了幾種方案的特點,你可以參考下。

圖片圖片

我提醒你注意,無論哪種方法,如果你想同時滿足簡單、高可用和高性能,就要有取舍,所以你要站在實際的業務中,說明你的選型所考慮的平衡點是什么。我個人在業務中比較傾向于選擇 Snowflake 算法,在項目中也進行了一定的改造,主要是讓算法中的 ID 生成規則更加符合業務特點,以及優化諸如時鐘回撥等問題。

當然,除了“怎么解決消息被重復消費的問題?”之外,面試官還會問到你“消息積壓”。 原因在于消息積壓反映的是性能問題,解決消息積壓問題,可以說明候選者有能力處理高并發場景下的消費能力問題。

你在解答這個問題時,依舊要傳遞給面試官一個這樣的思考過程: 如果出現積壓,那一定是性能問題,想要解決消息從生產到消費上的性能問題,就首先要知道哪些環節可能出現消息積壓,然后在考慮如何解決。

因為消息發送之后才會出現積壓的問題,所以和消息生產端沒有關系,又因為絕大部分的消息隊列單節點都能達到每秒鐘幾萬的處理能力,相對于業務邏輯來說,性能不會出現在中間件的消息存儲上面。毫無疑問,出問題的肯定是消息消費階段,那么從消費端入手,如何回答呢?

如果是線上突發問題,要臨時擴容,增加消費端的數量,與此同時,降級一些非核心的業務。通過擴容和降級承擔流量,這是為了表明你對應急問題的處理能力。

其次,才是排查解決異常問題,如通過監控,日志等手段分析是否消費端的業務邏輯代碼出現了問題,優化消費端的業務處理邏輯。

最后,如果是消費端的處理能力不足,可以通過水平擴容來提供消費端的并發處理能力,但這里有一個考點需要特別注意, 那就是在擴容消費者的實例數的同時,必須同步擴容主題 Topic 的分區數量,確保消費者的實例數和分區數相等。如果消費者的實例數超過了分區數,由于分區是單線程消費,所以這樣的擴容就沒有效果。

比如在 Kafka 中,一個 Topic 可以配置多個 Partition(分區),數據會被寫入到多個分區中,但在消費的時候,Kafka 約定一個分區只能被一個消費者消費,Topic 的分區數量決定了消費的能力,所以,可以通過增加分區來提高消費者的處理能力。

總結

至此,我們講解了 MQ 消息隊列的熱門問題的解決方案,無論是初中級還是高級研發工程師,本篇文章的內容都是你需要掌握的,你都可以從這幾點出發,與面試官進行友好的交流。我來總結一下今天的重點內容。

  • 如何確保消息不會丟失? 你要知道一條消息從發送到消費的每個階段,是否存在丟消息,以及如何監控消息是否丟失,最后才是如何解決問題,方案可以基于“ MQ 的可靠消息投遞 ”的方式。
  • 如何保證消息不被重復消費? 在進行消息補償的時候,一定會存在重復消息的情況,那么如何實現消費端的冪等性就這道題的考點。
  • 如何處理消息積壓問題? 這道題的考點就是如何通過 MQ 實現真正的高性能,回答的思路是,本著解決線上異常為最高優先級,然后通過監控和日志進行排查并優化業務邏輯,最后是擴容消費端和分片的數量。

在回答問題的時候,你需要特別注意的是,讓面試官了解到你的思維過程,這種解決問題的能力是面試官更為看中的,比你直接回答一道面試題更有價值。

另外,如果你應聘的部門是基礎架構部,那么除了要掌握本講中的常見問題的主線知識以外,還要掌握消息中間件的其他知識體系,如:

  • 如何選型消息中間件?
  • 消息中間件中的隊列模型與發布訂閱模型的區別?
  • 為什么消息隊列能實現高吞吐?
  • 序列化、傳輸協議,以及內存管理等問題
  • … >
責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2023-03-30 08:58:26

消息隊列RabbitMQ面試

2022-07-25 06:46:24

MQ中間件消息中間件

2019-04-08 09:31:55

OracleMySQL遷移

2017-09-23 15:17:21

散熱筆記本電腦藍屏

2010-07-07 14:28:52

繪制UML序列圖

2009-01-07 18:02:36

服務器虛擬化數據中心

2021-10-12 00:04:24

腳本備份MariDB

2010-06-13 09:18:45

綜合布線

2017-11-20 10:45:26

數據中心遷移IDC

2017-11-28 10:34:47

數據中心遷移IDC

2013-05-06 15:42:49

2017-09-22 06:58:06

窄帶物聯網NB-IoT物聯網

2011-07-04 16:40:39

QT 串口 QML

2021-08-29 23:40:51

手機華為功能

2012-06-21 09:45:43

虛擬化

2010-06-09 16:57:14

路由選擇協議

2011-05-18 11:31:56

數據安全數據備份

2009-09-07 14:39:14

2011-07-01 09:31:49

.net

2021-03-03 21:24:57

數據倉庫工具
點贊
收藏

51CTO技術棧公眾號

91香蕉亚洲精品| 亚洲国产97在线精品一区| 亚洲一区尤物| 国产成a人亚洲精v品无码| 国产精品a级| 精品视频中文字幕| 91高清国产视频| 欧美人动性xxxxz0oz| 99精品热视频| 国产精品久久久久久久久久| 国产又黄又爽又无遮挡| 日韩精品免费一区二区三区竹菊 | 五月天综合在线| 国产videos久久| 日韩一区二区三区在线视频| 日韩av在线综合| 成人片在线看| 久久精品欧美日韩精品| 97人人模人人爽视频一区二区| 日本三级黄色大片| 久久理论电影| 亚洲精品小视频| 黄色一级片免费播放| 综合久久2023| 亚洲激情六月丁香| 亚洲v欧美v另类v综合v日韩v| 国内精品国产成人国产三级| 久久激情一区| 久久人人爽人人爽人人片av高请| 精品人体无码一区二区三区| 欧美韩一区二区| 欧美一区二区三区爱爱| 亚洲视频在线观看一区二区三区| 国产乱码在线| 亚洲精品国产一区二区精华液 | 视频三区在线观看| 国产一区日韩二区欧美三区| 国产精品88a∨| 日韩欧美三级在线观看| 欧美永久精品| 色妞久久福利网| 真实乱视频国产免费观看| 国产主播性色av福利精品一区| 宅男噜噜噜66一区二区66| 黑森林精品导航| 法国空姐在线观看免费| 亚洲欧美日韩精品永久在线| 国产精品一区免费在线观看| 91精品久久久久久久久久另类 | 亚洲精品资源| 欧美激情一级精品国产| 91嫩草|国产丨精品入口| 青青草国产免费一区二区下载| 亚洲精品视频免费| 懂色av粉嫩av蜜乳av| 亚洲视频国产精品| 欧美成人精品二区三区99精品| 一级黄色高清视频| 国产在线不卡一区二区三区| 91精品欧美久久久久久动漫| 亚洲综合在线一区二区| 日韩视频一二区| 日韩亚洲电影在线| 中文字幕人妻熟女在线| 精品国产乱子伦一区二区| 亚洲高清久久网| 日本少妇色视频| 国产一区网站| 中文字幕亚洲无线码在线一区| 久久婷婷五月综合| 99久久99久久精品国产片桃花| 久久精品国产69国产精品亚洲| 国产精品18在线| 7777久久香蕉成人影院| 欧美肥老妇视频| 精品一区免费观看| 亚洲专区一区二区三区| 国产精品69av| 99国产成人精品| 成人国产一区二区三区精品| 精品久久久久久一区二区里番| 日色在线视频| 国产精品久久久久久久久免费相片| 综合久久国产| 欧美黑人xx片| 欧美色道久久88综合亚洲精品| 人妻熟女一二三区夜夜爱| 欧美精品高清| 欧美精品丝袜中出| 亚洲av综合色区无码另类小说| 好吊妞国产欧美日韩免费观看网站 | 欧美二区三区| 国产三级在线| 国产精品大尺度| 伊人网在线免费| 色a资源在线| 色婷婷综合在线| 亚洲精品第三页| 国产精品一线| 尤物精品国产第一福利三区| 992在线观看| 黄色亚洲在线| 国产精品久久久久久久久久久不卡| 亚洲天堂中文网| 毛片一区二区三区| aa成人免费视频| 天堂在线免费av| 中文字幕国产一区| 青青草视频国产| 亚洲同志男男gay1069网站| 欧美日韩午夜在线| 日本一级片在线播放| 成人三级视频| 97国产一区二区精品久久呦| 91精品国自产| 99国产精品视频免费观看| 天堂资源在线亚洲视频| 青春草视频在线| 欧美午夜电影在线播放| 屁屁影院国产第一页| 久久国产电影| 欧美一级大片在线观看| 亚洲国产福利视频| 亚洲国产精华液网站w| 妞干网视频在线观看| 在线看欧美视频| 精品粉嫩aⅴ一区二区三区四区| 婷婷色一区二区三区| 国内精品嫩模av私拍在线观看| 国产精品扒开腿做爽爽爽男男 | 黄色另类av| 国产精品欧美亚洲777777| 欧美一级在线免费观看| 亚洲私人黄色宅男| 成人毛片视频网站| 国产一区二区三区不卡av| 久久国产精品99国产精| 成人毛片一区二区三区| av午夜一区麻豆| 亚洲欧美日韩不卡| 精品视频在线一区二区在线| 亚洲国产精品成人一区二区| 国产又粗又长又硬| 蜜臀99久久精品久久久久久软件| 久久久福利视频| av影视在线看| 精品少妇一区二区| 超碰在线国产97| 久久99精品国产麻豆不卡| 欧美亚洲爱爱另类综合| 亚洲电影视频在线| 日韩欧美中文字幕精品| www日韩在线| 寂寞少妇一区二区三区| 水蜜桃亚洲精品| 视频二区不卡| 亚洲欧美在线播放| 亚洲免费在线观看av| 91麻豆国产精品久久| 黄色www网站| 欧美色资源站| 青草成人免费视频| 欧美18xxxxx| 一本久道中文字幕精品亚洲嫩| 草草影院第一页| 亚洲理伦在线| 欧美一区二区三区四区夜夜大片| 周于希免费高清在线观看| 日韩高清a**址| 日韩特级黄色片| 久久久久国产一区二区三区四区| 国产免费一区二区三区视频| 亚洲精品国模| 不卡伊人av在线播放| 亚洲精品久久久久久无码色欲四季| 亚洲老妇xxxxxx| www.美色吧.com| 亚洲伦理一区| 欧洲一区二区日韩在线视频观看免费| 中文不卡1区2区3区| 亚洲系列中文字幕| 日韩免费av网站| 亚洲免费大片在线观看| 日韩大尺度视频| 国产亚洲午夜| 色之综合天天综合色天天棕色 | 午夜亚洲福利| 久久av一区二区三区漫画| 成人免费看黄| 日韩一区二区三区在线播放| jlzzjlzzjlzz亚洲人| 亚洲精选免费视频| 极品粉嫩小仙女高潮喷水久久| 久久精品二区三区| 亚洲欧美日韩另类精品一区二区三区| 99久久这里有精品| 国模极品一区二区三区| 久久精品国产亚洲a∨麻豆| 欧美精品免费视频| 久久精品99久久久久久| 欧美国产一区在线| 亚洲一区二区偷拍| 久久亚洲欧洲| 桥本有菜av在线| 蜜桃一区二区三区| 91久久久久久久| а√在线中文网新版地址在线| 久久精品91久久久久久再现| 丰满大乳国产精品| 欧美亚洲综合另类| 国产主播在线观看| 国产精品丝袜久久久久久app| 亚洲熟女一区二区三区| 蜜桃av一区二区| 玩弄中年熟妇正在播放| 天天天综合网| 欧美大香线蕉线伊人久久国产精品| 自拍偷拍亚洲| 日韩免费黄色av| 国产在线激情视频| 亚洲欧美日本另类| www日本高清| 欧美日韩成人在线| 国产剧情在线视频| 亚洲一区二区三区小说| 久久久久久成人网| 岛国一区二区三区| 欧洲美女亚洲激情| 免费欧美日韩国产三级电影| 黄色www网站| 一区二区日韩欧美| 亚洲精品永久www嫩草| 婷婷综合一区| 国产三级精品在线不卡| www.成人在线.com| 国产精品自拍视频| 日本不良网站在线观看| 97精品视频在线播放| 免费网站在线观看人| 久久夜精品香蕉| 在线看黄色av| 一区二区在线视频| 色呦呦中文字幕| 精品999在线播放| 国内精品国产成人国产三级| 欧美日韩高清在线播放| 久久这里只有精品9| 一本大道久久a久久精二百| 黄色一级视频免费观看| 亚洲自拍偷拍欧美| wwwav国产| 一区二区三区不卡视频| 青娱乐国产精品| 亚洲激情一二三区| 国产精久久一区二区三区| 久久美女艺术照精彩视频福利播放| 女同性恋一区二区三区| 成人午夜电影久久影院| 亚洲一区和二区| 国产99精品国产| 毛茸茸free性熟hd| 91在线视频播放地址| 国产一级二级在线观看| 91网站视频在线观看| 给我免费观看片在线电影的| 91丨porny丨国产| 少妇按摩一区二区三区| 国产精品久久久久三级| 日韩精品一区二区三区在线视频| 自拍av一区二区三区| 国产精品三区在线观看| 亚洲精品视频在线观看网站| 免费精品在线视频| 亚洲午夜免费视频| 亚洲精品国产精品乱码| 精品成人久久av| 无码人妻丰满熟妇奶水区码| 欧美日韩在线三区| 成人一级免费视频| 日韩午夜在线观看| 四季av日韩精品一区| 亚洲人a成www在线影院| a天堂中文在线88| 欧美大胆a视频| 看黄在线观看| 国产精品欧美日韩久久| 免费看日产一区二区三区 | 亚洲国产精品二十页| 97精品在线播放| 一区二区三区在线不卡| 亚洲精品www久久久久久| 欧美三级电影在线观看| www.av日韩| 亚洲精品综合精品自拍| 秋霞成人影院| 国模精品视频一区二区| 综合久草视频| 麻豆av福利av久久av| 中文字幕中文字幕精品| 一级黄色免费在线观看| 国产伊人精品| 色婷婷狠狠18| youjizz国产精品| 精品熟妇无码av免费久久| 一区二区三区四区高清精品免费观看 | 久久综合五月婷婷| 亚洲国产午夜伦理片大全在线观看网站| 中文字幕免费精品| 国产一区二区三区精彩视频| 国产一区在线精品| 久久亚洲AV成人无码国产野外| 国产精品久久免费看| 国产大片aaa| 日韩一区二区三区精品视频| 奇米影视888狠狠狠777不卡| 久久中文字幕在线| 校园春色亚洲色图| 成人做爰www免费看视频网站| 中日韩免视频上线全都免费| 日韩精品一区二区三区电影| 国产农村妇女精品一区二区| www.色.com| 国产精品三级视频| 区一区二在线观看| 精品电影一区二区| 免费大片黄在线| 国产精品mp4| 91精品啪在线观看国产爱臀| 伊人色综合久久天天五月婷| 亚洲一区二区三区四区五区午夜| 国产精品999.| 国产精品午夜春色av| www日韩精品| 日韩av一卡二卡| 日韩三级免费| 91精品视频在线播放| 日韩在线精品| 亚洲免费av一区二区三区| 972aa.com艺术欧美| 精品无码久久久久| 日韩欧美中文字幕精品| 超碰人人在线| 91原创国产| 亚洲网色网站| 国产高清999| 成人免费在线观看入口| 97超视频在线观看| 日韩中文字幕网站| 欧美aaa视频| 欧洲精品国产| 秋霞av亚洲一区二区三| 最新黄色av网址| 欧美日韩国产天堂| 免费日本一区二区三区视频| 国产日韩中文字幕在线| 欧美独立站高清久久| 57pao国产成永久免费视频| 国产精品国产三级国产普通话蜜臀| 亚洲精品91天天久久人人| 亚洲欧美在线看| 四虎影视成人精品国库在线观看| 亚洲欧洲精品在线| 精品一区二区三区久久| 男人的午夜天堂| 欧美一区二区三区在线电影| 伊人福利在线| 成人9ⅰ免费影视网站| 国语精品一区| 北京富婆泄欲对白| 色猫猫国产区一区二在线视频| 国产在线超碰| 成人国产精品av| 国产精品国产一区| 最新版天堂资源在线| 欧美午夜激情视频| av成人手机在线| 国产精品第3页| 婷婷综合激情| 三级黄色片免费看| 欧美日韩午夜剧场| аⅴ资源新版在线天堂| 成人xxxxx| 亚洲黄色大片| av小说在线观看| 欧美日韩国产一级二级| 免费网站在线观看人| 免费av在线一区二区| 国产精品主播| 在线不卡av电影| 91精品国产综合久久精品性色| 国产在线看片免费视频在线观看| 欧美精品二区三区四区免费看视频| 精品无码三级在线观看视频| 亚洲天堂日韩av| 日韩有码在线播放| 国产极品模特精品一二| 欧美私人情侣网站| 亚洲人成网站色在线观看| 艳母动漫在线看| 成人激情视频小说免费下载|