色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

RocketMQ中各類重復消費的原理淺析

jf_uPRfTJDa ? 來源: 移動Labs ? 2024-01-08 09:29 ? 次閱讀

Labs 導讀

隨著大數據和云計算時代的到來,我國的各個產業每天都在產生不可估計的數據,以及對數據的各式各樣的需求,消息中間件在處理數據、消費數據的過程中越來越受到重視。在高并發、微服務、分布式的場景下,如何合理地利用消息中間件,如何保證MQ消費消息的冪等性?所謂知其然,才能知其所以然,本文將通過RocketMQ作為例子,來扒一扒什么情況下會導致重復消費。

作者:李佳斌

單位:中國移動智慧家庭運營中心

Part 01RocketMQ如何生產和消費消息

先簡單介紹下RocketMQ正常生產消息和消費消息的流程,如下圖。

1.生產者在發送消息之前根據負載均衡策略(默認是輪詢)選擇一個Queue,然后跟這個Queue所在的機器建立連接,把消息發送到這個Queue上。

2.消費者消費這個Queue,就能獲取到對應的消息。

8861f07e-ad40-11ee-8b88-92fbcf53809c.png

- 問題出現

當異常情況出現時,如消息發送超時或者消息消費超時,RocketMQ為保證消息發送成功,會啟動重試機制,選擇另一臺機器的Queue重發。現在假設有這樣一種情況,消費者實際正確接收到了消息,只是由于網絡波動導致響應超時了,那就會出現消息重復發送,導致消費者重復消費的情況出現。

那除此之外,還有沒有其他情況會導致消息重復消費的情況呢?總結起來一共有如下幾種情況。

1)消息發送異常時的重復消費

2)消費消息時拋出了異常

3)消費者提交offset失敗

4)Broker持久化offset失敗

5)主從同步失敗

6)重平衡

7)清理長時間消費的消息

Part 02淺析各類情況

- 消費消息時拋出異常

問題分析一

RocketMQ在并發消費的模式下會調用MessageListenerConcurrently的consumeMessage方法,入參是msgs集合。當調用該方法消費消息出現異常時,返回的結果status就會是null。這種情況下會導致status被設置為RECONSUME_LATER,也就是說消息之后會被重復消費。

問題分析二

傳入的是msgs集合。上述原因一中消息處理之后,不管成功失敗,都會對結果進行處理。而集合中的任意一個失敗,都會導致status被設置為RECONSUME_LATER。在對結果處理是,判斷到RECONSUME_LATER時,就會對msgs重新遍歷并發送消息,重新消費,從而導致之前成功處理的消息都會被重復消費。不過好在msgs消息的數量默認情況下是1。

88792f32-ad40-11ee-8b88-92fbcf53809c.png

- 消費者提交offset失敗

何為offset

producer發送消息到broker,Rocketmq會將消息的內容持久化到commitLog文件中,再分發到topic下的消費隊列consume Queue,消費者提交消費請求時,broker從該consumer負責的消費隊列中根據請求參數傳入的起始offset來獲取需要消費的消息索引信息,再從commitLog中獲取具體的消息內容返回給consumer。消費成功之后,消費者提交offset,來記錄這個queue消費到哪個位置了。

問題分析

RocketMq設計的時候,消費完消息,并不是同步提交offset,而是將offset保存到內存中,通過一個定時任務(默認是5S一次),以網絡請求的方式將offset提交給broker。如果最新的offset還沒提交,此時服務器宕機了,那么重啟之后,就會從broker中讀取到之前的提交的offset,并從此處開始消費,此時就會出現重復消費的情況了。

888b513a-ad40-11ee-8b88-92fbcf53809c.png

- broker持久化offset失敗

問題分析

與消費者提交offset同理,Broker為了防止數據丟失,會將offset持久化到磁盤中。同樣的也是通過一個默認5S的定時任務來處理持久化操作。所以offset的完整過程就如下圖。當broker宕機時,就會導致offset丟失,此時如果消費者重新拉取消費進度,就會比實際消費的進度要低,導致重復消費。

88a54d42-ad40-11ee-8b88-92fbcf53809c.png

- 主從同步失敗

問題分析

為保證RocketMQ服務的高可用,一般項目中都會啟用主從備份的模式,當主節點掛掉之后,從節點就會升級為主節點對外提供服務。因此就需要進行主從同步,保證數據的一致性。默認情況下每隔10S,從節點會向主節點請求,同步元數據,包括消費進度。此時如果主節點宕機了,從節點就無法獲取到10S之內的消費進度,自然也就會導致重復消費。

88bf60a6-ad40-11ee-8b88-92fbcf53809c.png

- 重平衡

何為重平衡

RocketMQ的消費者有兩種模式,集群消費模式和廣播消費模式,絕大多數場景采用的都是集群消費模式。前面提到的消費進度就是在集群消費模式下才會存在。集群消費模式中有一個消費組的概念。一個消費組可以有多個消費者,不同消費組之間消費消息互不干擾,而同一消費組的消費者按照一定的算法分配消息隊列進行消息消費,保證一個消息只能被一個消費組消費一次。當消費組中的消費組增加或者減少時就會觸發重平衡。如圖,原先消費組中有兩個消費者,平均消費4個隊列,每個消費組2個隊列;當加入了一個新的消費者時,為了保證新的消費者能夠消費消息,就會進行重平衡,重新分配消息隊列。

88d971d0-ad40-11ee-8b88-92fbcf53809c.png

問題分析

假設在重平衡發生時,此時消費者2還在正常消費Queue4,當消費者3加入,重平衡完成時,此時消費者2判斷到Queue4已經不屬于自己消費了,就會將Queue4設置為dropped,消費完成時,發現隊列是dropped狀態,那么消費者2的消費進度offset就不會被提交。成功消費了消息,但是消費進度卻沒有被提交,于是當消費者3開始消費消息時,就會從服務端拉取到之前的消費進度,造成隊列4的消息被重復消費。

- 清理長時間消費的消息

清理機制講解

RocketMQ中有一個機制會定時清理長時間正在消費的消息,默認是15分鐘執行一次清理任務。之所以這么做,是有原因的。我們說過,消息被消費之后,就會提交offset。當一個線程消費了所有消息時,就會把消息從集合中移除,提交的消息進度offset就是msg5的offset+1。

假設,現在是兩個線程消費,線程2消費完成,之后提交offset,但是此時線程1還在處理前兩條消息,因此為了保證消費消息的不丟失,移除之后發現集合中還有剩余消息,就會把msg1的offset返回提交上去。而一旦集合最前面的消息長時間處理,就會導致這個消費進度一直在最前面。此時如果服務器重啟,就會導致很多消費過的消息都會被重復消費。因此引入了清理長時間消費的機制。

88f595a4-ad40-11ee-8b88-92fbcf53809c.png

問題分析

引入清理長時間消費的消息機制后,一旦發現某個消息已經處理超過15分鐘了,就會將消息移除,保障后續消息消費進度的正常提交,之后會隔一定的時間再次消費這個被移除的消息。但是,這個消息雖然被移除了,卻并不是沒有消費過,因此再次消費就會導致重復消費的問題出現。

Part 03總結

RocketMq的官方文檔中對消息傳遞有這樣的解釋:RocketMq確保所有消息至少被傳遞一次,在大多數情況下,消息不會重復。可見RocketMq為了保證消息的不丟失,犧牲了消息投遞的重復率。因此我們在使用RokcetMq時需要合理使用它的特點,設計合理的冪等技術方案來解決重復消費的問題。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 云計算
    +關注

    關注

    39

    文章

    7824

    瀏覽量

    137450
  • Queue
    +關注

    關注

    0

    文章

    16

    瀏覽量

    7264
  • 負載均衡
    +關注

    關注

    0

    文章

    112

    瀏覽量

    12368
  • 大數據
    +關注

    關注

    64

    文章

    8893

    瀏覽量

    137461

原文標題:技術 | RocketMQ中各類重復消費的原理淺析

文章出處:【微信號:5G通信,微信公眾號:5G通信】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    RocketMQ入門手冊

    RocketMQ入門篇
    發表于 10-09 14:13

    Rocketmq怎么安裝

    Rocketmq 安裝步驟
    發表于 10-24 07:47

    淺析伺服系統應用的慣量匹配問題

    剛性、慣量、響應時間及伺服增益調整之間的關系 淺析伺服系統應用的慣量匹配問題-慣量匹配
    發表于 09-07 07:01

    在Linux系統下部署RocketMQ單機實例

    前言這篇文章以4.3.0版本為標準進行講述在linux下部署RocketMQ單機實例,在此之前需要已配置JAVA環境。下載程序包直接使用一般就下載已經編譯好的二進制文件就好了,下載好以后&
    發表于 11-11 16:29

    展望Apache RocketMQ5.0 | 談RocketMQ的過去、現在和未來

    RocketMQ 創始人,阿里巴巴中間件高級技術專家 馮嘉 向開發者們分享了Apache RocketMQ 的過去、現在和未來,以及對RocketMQ5.0的展望。本文是根據馮嘉的現場分享所整理,為大家回顧分享
    發表于 08-14 16:37 ?212次閱讀

    全面簡析RocketMQ 架構

    Producer 負責生產消息,Consumer 負責消費消息,Broker 負責存儲消息。每個 Broker 可以存儲多個Topic的消息,每個Topic的消息也可以分片存儲于集群的不同的Broker
    的頭像 發表于 06-12 17:07 ?2040次閱讀

    Apache RocketMQ MQTT協議架構模型

    rocketmq-mqtt.zip
    發表于 04-20 10:45 ?0次下載
    Apache <b class='flag-5'>RocketMQ</b> MQTT協議架構模型

    開源軟件-RocketMQ Externals Apache RocketMQ的擴展項目

    ./oschina_soft/rocketmq-externals.zip
    發表于 06-23 15:03 ?0次下載
    開源軟件-<b class='flag-5'>RocketMQ</b> Externals Apache <b class='flag-5'>RocketMQ</b>的擴展項目

    如何在RocketMQ合理使用重試機制

    RocketMQ 的重試機制包括三部分,分別是生產者重試,服務端內部數據復制遇到非預期問題時重試,消費消費重試。
    的頭像 發表于 11-23 10:15 ?1136次閱讀

    淺析LeetCode 83刪除排序鏈表重復元素

    給定一個已排序的鏈表的頭 head , 刪除所有重復的元素,使每個元素只出現一次 。返回 已排序的鏈表 。
    的頭像 發表于 02-06 10:25 ?747次閱讀

    聊聊RocketMQ的主從復制

    RocketMQ 主從復制是 RocketMQ 高可用機制之一,數據可以從主節點復制到一個或多個從節點。
    的頭像 發表于 07-04 09:42 ?631次閱讀
    聊聊<b class='flag-5'>RocketMQ</b>的主從復制

    RocketMQ和RabbitMQ的區別

    化:RocketMQ將消息存儲在磁盤上,保證消息的可靠性;RabbitMQ默認將消息保存在內存,可以通過插件進行持久化。 可用性:RocketMQ具備分布
    的頭像 發表于 07-24 13:39 ?1.4w次閱讀

    RocketMQ在業務消息場景的優勢有哪些呢?

    RocketMQ 5.0 是消息事件流一體的實時數據處理平臺,是業務消息領域的事實標準,很多互聯網公司在業務消息場景會使用 RocketMQ
    的頭像 發表于 08-07 11:36 ?795次閱讀
    <b class='flag-5'>RocketMQ</b>在業務消息場景的優勢有哪些呢?

    磁盤RocketMQ構建的索引結構

    RocketMQ 廣泛使用于各類業務場景,在實際生產場景,用戶通常會選擇消息 ID 或者特定的業務 Key(例如學號,訂單號)來查詢和定位特定的一批消息,進而定位分布式系統
    的頭像 發表于 12-22 10:43 ?409次閱讀
    磁盤<b class='flag-5'>中</b><b class='flag-5'>RocketMQ</b>構建的索引結構

    RocketMQ協議是什么?RocketMQ協議特點

    分布式消息系統中生產者和消費者之間的高效可靠通信。它支持同步和異步消息傳遞模式,可以實現靈活和響應迅速的通信方式。 RocketMQ協議基于發布-訂閱消息模式,生產者將消息發布到特定的主題,消費者訂閱這些主題以接收消息。該協議通
    的頭像 發表于 01-03 16:11 ?820次閱讀
    主站蜘蛛池模板: 久久精选视频| 日韩亚洲欧洲在线rrrr片| 同桌上课把奶露出来给我玩| 国产精品97久久AV麻豆| 亚洲高清中文字幕| 精品一品国产午夜福利视频 | 中文字幕蜜臀AV熟女人妻| 免费视频国产| 高跟丝袜岳第一次| 亚洲免费精品| 年轻的女教师2017韩国在线看| 国产36d在线观看| 一本大道手机在线看| 欧美精品做人一级爱免费| 国产久久热99视频| 18禁无遮遮挡羞漫画免费阅读 | 91素人约啪| 污文乖不疼的| 美女在线永久免费网站| 国产精品人妻99一区二| 最新男同鸭子ktv| 乡村教师电影完整版在线观看| 久久无码AV亚洲精品色午夜麻豆| 成人免费视频在线| 一个人看的www视频动漫版| 三叶草未满十八岁| 久久亚洲AV成人无码国产漫画| 俄罗斯大肥BBXX| 最近更新2019中文字幕国语| 神马老子影院午夜伦| 快播电影频道| 好看的电影网站亚洲一区| 阿娇和冠希13分钟在线观看| 亚洲中文字幕永久在线| 日韩欧美成人免费中文字幕| 快播性爱电影| 国产午夜人成在线视频麻豆| HEYZO精品无码一区二区三区| 一级淫片bbbxxx| 性夜夜春夜夜爽AA片A| 欧美大jiji|