国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

MQ為什么會(huì)丟消息?如何保證不丟失消息

網(wǎng)絡(luò) 通信技術(shù)
當(dāng)生產(chǎn)者往 MQ 中寫(xiě)數(shù)據(jù)時(shí),可能出現(xiàn)網(wǎng)絡(luò)故障,消息壓根就沒(méi)到達(dá) MQ 內(nèi)部,生產(chǎn)者端對(duì)這個(gè)異常沒(méi)有捕獲,不做任何處理,這種場(chǎng)景會(huì)導(dǎo)致消息丟失。

 [[385981]]

本文轉(zhuǎn)載自微信公眾號(hào)「菜鳥(niǎo)飛呀飛」,作者劉進(jìn)坤。轉(zhuǎn)載本文請(qǐng)聯(lián)系菜鳥(niǎo)飛呀飛公眾號(hào)。

一、前言

面大廠(chǎng)時(shí),MQ 這一中間件基本都是必問(wèn)的,本文是面試時(shí)被問(wèn)到的其中一題的答案。

二、為什么丟消息

一條消息從產(chǎn)生到被消費(fèi),中間會(huì)經(jīng)歷三個(gè)環(huán)節(jié):生產(chǎn)者、MQ 內(nèi)部、消費(fèi)者,消息在這三個(gè)環(huán)節(jié)中均有可能出現(xiàn)丟失。

1. 在生產(chǎn)者環(huán)節(jié)丟失

當(dāng)生產(chǎn)者往 MQ 中寫(xiě)數(shù)據(jù)時(shí),可能出現(xiàn)網(wǎng)絡(luò)故障,消息壓根就沒(méi)到達(dá) MQ 內(nèi)部,生產(chǎn)者端對(duì)這個(gè)異常沒(méi)有捕獲,不做任何處理,這種場(chǎng)景會(huì)導(dǎo)致消息丟失。

當(dāng)消息達(dá)到 MQ 所在的機(jī)器,但是 MQ 出現(xiàn)了異常,返回異常給生產(chǎn)者端,生產(chǎn)者對(duì)異常沒(méi)做相應(yīng)處理,導(dǎo)致消息丟失

2. 在 MQ 環(huán)節(jié)丟失

當(dāng)消息達(dá)到 MQ 內(nèi)部后,消息會(huì)先存于內(nèi)存當(dāng)中,然后再持久化到磁盤(pán)。如果在消息處于內(nèi)存當(dāng)中,還未來(lái)得及刷入磁盤(pán)時(shí),MQ 所在機(jī)器宕機(jī),此時(shí),消息會(huì)丟失。

即使消息持久化到磁盤(pán)了,但當(dāng)前機(jī)器的磁盤(pán)發(fā)生損壞,消息依舊會(huì)丟失。

3. 在消費(fèi)者環(huán)節(jié)丟失消息

  • 當(dāng)消息達(dá)到消費(fèi)者端時(shí),如果消費(fèi)者開(kāi)啟了 Auto ACK,那么消費(fèi)者消費(fèi)到消息后,就會(huì)自動(dòng)提交 offset 到 MQ,如果此時(shí)消費(fèi)者還沒(méi)來(lái)得及處理消息對(duì)應(yīng)的業(yè)務(wù)邏輯,機(jī)器宕機(jī)了或者被新手 kill -9 pid 了,此時(shí)消息也就被丟失了。即使機(jī)器重新恢復(fù)后,由于已經(jīng)提交了之前消息的 offset,所以 MQ 不會(huì)再將之前的消息推送給消費(fèi)者,因此這條消息丟失。(這也是很多文章都說(shuō)不準(zhǔn)使用 kill -9 pid 的其中原因之一)
  • 消費(fèi)者沒(méi)有開(kāi)啟 Auto ACK,但是消費(fèi)者消費(fèi)到消息后,將消息扔到了線(xiàn)程池,然后提交 offset,讓線(xiàn)程池異步去處理消息。如果線(xiàn)程池中的任務(wù)還沒(méi)處理完,機(jī)器宕機(jī)或者 OOM 等異常,這也將導(dǎo)致消息沒(méi)被處理,從而丟失。

三、如何保證不丟消息

消息在上述三個(gè)環(huán)節(jié)均有可能出現(xiàn)丟失,因此需要保證上述這三個(gè)環(huán)節(jié)均不出現(xiàn)丟數(shù)據(jù)的可能,才能完全保證消息不丟失。

1. 生產(chǎn)者

當(dāng)往 MQ 中寫(xiě)消息出現(xiàn)異常時(shí),采用 try...catch... 捕獲異常,在異常代碼塊中重試。

如果是 RocketMQ,可以直接使用 RokcetMQ 的事務(wù)消息,來(lái)保證消息不丟失。至于為什么 RocketMQ 為什么能保證消息不丟失。

2. MQ

對(duì)于 MQ 而言,要保證消息不丟失,一方面是要保證消息要持久化到磁盤(pán),另一方面是需要保證消息有多個(gè)副本。在不同的 MQ 中,對(duì)這兩點(diǎn)的處理方式均不太一樣,下面主要以 kafka 和 RocketMQ 為例說(shuō)明。

對(duì)于 kafka 而言,需要保證如下三點(diǎn):

  1. 要求每個(gè) partition 的副本數(shù)大于 1(replication factor > 1)
  2. 要求 kafka 服務(wù)端設(shè)置 broker.insync.replicas 參數(shù)的值大于 1,它的意思是要求至少有一個(gè) flower 在和 leader 同步
  3. 將 acks=all,在寫(xiě)數(shù)據(jù)時(shí),要求消息寫(xiě)到所有的 leader 和 flower 之后,才認(rèn)為消息寫(xiě)成功。

對(duì)于 RocketMQ 而言,需要保證以下幾點(diǎn):

  1. 基于 Dledger 的 broker 主從架構(gòu),每個(gè)主 broker 需要掛至少 2 個(gè) slave broker。
  2. 采用同步刷盤(pán)策略。

同步刷盤(pán)指的是 MQ 接收到生產(chǎn)的消息時(shí),將消息先寫(xiě)入到 OS cache 中,然后再將 OS cache 刷入到磁盤(pán)后,才返回 success 給生產(chǎn)者;與之對(duì)應(yīng)的是異步刷盤(pán),異步刷盤(pán)指的是將將消息寫(xiě)入到 OS cache 中后就返回 success 給生產(chǎn)者,然后由操作系統(tǒng)決定 OS cache 中的數(shù)據(jù)什么時(shí)候刷入到磁盤(pán)。顯然,同步刷盤(pán)雖然能保證數(shù)據(jù)不丟失,但是性能會(huì)比較低,同步刷盤(pán)時(shí),MQ 的吞吐量沒(méi)有異步刷盤(pán)高。

3. 消費(fèi)者

關(guān)閉 Auto ACK。消費(fèi)到消息后,處理完業(yè)務(wù)邏輯后再手動(dòng)提交 offset。

不使用異步線(xiàn)程池處理消息。

四、總結(jié)

保證消息不丟失是一個(gè)非常苛刻的要求,要保證消息不丟失就需要犧牲系統(tǒng)的性能(生產(chǎn)者的處理邏輯變復(fù)雜,MQ 的吞吐量降低,消費(fèi)者消費(fèi)速度下降等),所以需要結(jié)合具體的業(yè)務(wù)場(chǎng)景來(lái)決定是不是需要百分百保證消息不丟失。通常而言,對(duì)于核心鏈路:如訂單、交易等相關(guān)的業(yè)務(wù),基本都需要保證保證消息百分百不丟失。

 

責(zé)任編輯:武曉燕 來(lái)源: 菜鳥(niǎo)飛呀飛
相關(guān)推薦

2024-08-06 09:55:25

2016-10-11 16:31:56

微信服務(wù)器消息

2025-07-21 09:02:45

2020-10-26 09:19:11

線(xiàn)程池消息

2021-10-22 08:37:13

消息不丟失rocketmq消息隊(duì)列

2025-11-11 09:05:09

2024-06-18 08:26:22

2020-10-18 07:25:55

MQ消息冪等架構(gòu)

2022-12-26 18:53:00

MQ宕機(jī)倉(cāng)儲(chǔ)服務(wù)

2021-08-04 07:47:18

Kafka消息框架

2024-04-09 09:08:09

Kafka消息架構(gòu)

2021-09-13 07:23:53

KafkaGo語(yǔ)言

2024-01-16 08:24:59

消息隊(duì)列KafkaRocketMQ

2023-09-13 08:14:57

RocketMQ次數(shù)機(jī)制

2016-11-02 13:12:31

微信離線(xiàn)消息

2022-08-26 05:24:04

中間件技術(shù)Kafka

2024-11-11 07:05:00

Redis哨兵模式主從復(fù)制

2024-02-26 08:10:00

Redis數(shù)據(jù)數(shù)據(jù)庫(kù)

2025-10-28 08:21:32

2022-03-31 08:26:44

RocketMQ消息排查
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

北岛玲一区二区三区| 国产精品夜夜夜一区二区三区尤| 国产精品久久久久久久久久直播| 日韩电影毛片| 亚洲成人免费电影| 一本一本a久久| 成人3d动漫在线观看| 亚洲女人被黑人巨大进入| 无圣光视频在线观看| 99re视频这里只有精品| 欧美一区二区三区电影在线观看| 久久久久久毛片免费看| 精品丝袜一区二区三区| 成人免费高清在线播放| 国产精品色在线观看| 日本丰满大乳奶| 亚洲激情婷婷| 国产精品欧美激情在线播放| 国产亚av手机在线观看| 26uuu色噜噜精品一区二区| 色香阁99久久精品久久久| 亚洲午夜无码av毛片久久| 精品久久91| xxx欧美精品| 女同一区二区免费aⅴ| 久久国产精品影片| 快射av在线播放一区| 宅男网站在线免费观看| 国产精品91一区二区三区| 欧美激情一级欧美精品| 午夜不卡影院| 日韩欧美国产一二三区| jzzjzzjzz亚洲成熟少妇| 亚洲精品一卡二卡| 色婷婷成人在线| 91视视频在线观看入口直接观看www| 日韩精彩视频在线观看| 青草成人免费视频| 日韩三级影视| 欧美亚洲国产一区二区三区va| 美女黄色免费看| 午夜一区在线| 成人网欧美在线视频| 成人高潮视频| 久久国内精品一国内精品| 国产在线高潮| 日本韩国视频一区二区| 可以在线看黄的网站| 精品一区二区三区蜜桃| 久久伊人精品天天| 欧美激情成人网| 猛男gaygay欧美视频| 久久久精品免费| 成人在线视频国产| 色综合久久av| 成人三级在线| 欧美色123| 国产欧美综合精品一区二区| 最新欧美人z0oozo0| 国产精品v欧美精品∨日韩| 亚洲免费精品| 一区二区在线播放视频| 99re这里只有精品6| 日韩中文字幕在线视频观看| 国产高清亚洲一区| 国产 日韩 亚洲 欧美| 久久国产精品久久w女人spa| 国产精品久久7| 午夜亚洲一区| www.激情网| 91老师片黄在线观看| 在线观看污视频| 26uuu欧美| 中文在线播放| 欧美日韩三级一区| 久久国际精品| 国产精品视频免费在线| 成人久久久久| 久久久久久久免费视频| 国产日韩欧美麻豆| 日本免费视频| 成人激情免费网站| 国产日韩精品在线| 人人九九精品视频| 成人动漫在线观看视频| 亚洲欧美一区二区三区孕妇| 九色精品91| 亚洲大胆人体av| 日韩一区中文| 国产成人啪精品视频免费网| 一本一本久久| 国产高清不卡无码视频| 自拍偷拍国产亚洲| 九一九一国产精品| 黄色资源在线看| xxxxx成人.com| 日韩精品成人一区二区在线| 羞羞小视频视频| 久久色精品视频| 丝袜美腿亚洲一区| 免费在线看v| 91av在线视频观看| 国产盗摄一区二区三区| 国产高清视频在线观看| 亚州成人av在线| 94色蜜桃网一区二区三区| 久久亚洲导航| 亚洲精品免费在线视频| 国产欧美日韩综合精品一区二区| 在线视频1区2区| 国产九色91| 亚洲成avwww人| 99视频精品| 一级毛片国产| 777奇米四色成人影色区| 国产区在线视频| 精品国产成人系列| 亚洲激情精品| 亚洲www.| 啊v在线视频| 成人精品福利| 中文字幕一区日韩电影| 欧美在线高清| 国产亚洲综合视频| 欧美三级日本三级少妇99| 涩涩屋成人免费视频软件| 精品一区二区三区免费视频| 阿v免费在线观看| 亚洲已满18点击进入在线看片| 一区二区三区高清不卡| 57pao国产一区二区| 一本大道熟女人妻中文字幕在线| 欧美天堂亚洲电影院在线播放| 精品国产不卡| 欧美孕妇孕交xxⅹ孕妇交| 国产精品美女呻吟| 福利视频一区二区| jlzzjlzz亚洲日本少妇| 精品在线网站观看| 97在线观看免费观看高清| 宅男一区二区三区| 中日韩美女免费视频网站在线观看| 久久蜜桃一区二区| 精品国产一区二区三区| 日本成人网址| 丰满爆乳一区二区三区| 欧美极品少妇xxxxⅹ喷水| 欧美一卡二卡三卡| 国产日产高清欧美一区二区三区| 国产精品美女久久久久久免费| 成人高清视频在线| 91av资源在线| 四虎一区二区| 久久亚洲一区二区| 50路60路老熟妇啪啪| 免费看成年人视频在线观看| 啊v视频在线一区二区三区| 性伦欧美刺激片在线观看| 亚洲综合图片| 国产成人精品一区二区在线| 国产精品久久影院| 成人免费网站观看| 日本美女高清在线观看免费| 少妇久久久久久被弄到高潮| 国产成人免费av电影| 欧美成人video| 亚洲成人av中文| 亚洲电影中文字幕在线观看| 成人综合在线网站| 国产精品一区二区久激情瑜伽| 蜜臀av免费一区二区三区| 午夜欧美巨大性欧美巨大| 五月天婷婷在线视频| 中文字幕在线影院| 爱情岛论坛vip永久入口| 一区二区精品国产| 亚洲国产欧洲综合997久久| 91九色在线免费视频| 成人网在线免费看| 成人午夜在线影院| 成人黄色免费网站在线观看| 国产精品久久久久久网站| 538国产精品一区二区免费视频| 国产91九色视频| 亚洲精品视频久久| 色老头久久综合| 国产精品美女一区二区| 中文字幕一区二区三区在线视频| 成人免费毛片嘿嘿连载视频…| 国产精品蜜臀| 精品精品久久| 日本高清成人免费播放| 91精品国产99久久久久久红楼| 色婷婷精品大在线视频| 夜久久久久久| 在线看片国产福利你懂的| 国产一区二区视频免费在线观看| 日韩av免费在线播放| 欧美亚洲尤物久久| 国产精品影视天天线|