日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 架構(gòu)師社區(qū)
[導(dǎo)讀]大型互聯(lián)網(wǎng)公司一般都會要求消息傳遞最大限度的不丟失,比如用戶服務(wù)給代金券服務(wù)發(fā)送一個消息,如果消息丟失會造成用戶未收到應(yīng)得的代金券,最終用戶會投訴。為避免上面類似情況的發(fā)生,除了做好補(bǔ)償措施,更應(yīng)該在系設(shè)計的時候充分考慮各種異常,設(shè)計一個穩(wěn)定、高可用的消息系統(tǒng)。

刨根問底,Kafka消息中間件到底會不會丟消息

大型互聯(lián)網(wǎng)公司一般都會要求消息傳遞最大限度的不丟失,比如用戶服務(wù)給代金券服務(wù)發(fā)送一個消息,如果消息丟失會造成用戶未收到應(yīng)得的代金券,最終用戶會投訴。

為避免上面類似情況的發(fā)生,除了做好補(bǔ)償措施,更應(yīng)該在系設(shè)計的時候充分考慮各種異常,設(shè)計一個穩(wěn)定、高可用的消息系統(tǒng)。

認(rèn)識Kafka

看一下維基百科的定義

Kafka是分布式發(fā)布-訂閱消息系統(tǒng)。它最初由LinkedIn公司開發(fā),之后成為Apache項目的一部分。

Kafka是一個分布式的,可劃分的,冗余備份的持久性的日志服務(wù)。它主要用于處理活躍的流式數(shù)據(jù)。

kafka架構(gòu)

Kafka的整體架構(gòu)非常簡單,是顯式分布式架構(gòu),主要由producer、broker(kafka)和consumer組成。

刨根問底,Kafka消息中間件到底會不會丟消息
Kafka架構(gòu)(精簡版)

Producer(生產(chǎn)者)可以將數(shù)據(jù)發(fā)布到所選擇的topic(主題)中。生產(chǎn)者負(fù)責(zé)將記錄分配到topic的哪一個 partition(分區(qū))中??梢允褂醚h(huán)的方式來簡單地實現(xiàn)負(fù)載均衡,也可以根據(jù)某些語義分區(qū)函數(shù)(如記錄中的key)來完成。

Consumer(消費者)使用一個consumer group(消費組)名稱來進(jìn)行標(biāo)識,發(fā)布到topic中的每條記錄被分配給訂閱消費組中的一個消費者實例。消費者實例可以分布在多個進(jìn)程中或者多個機(jī)器上。

Kafka到底會不會丟失消息?

在討論kafka是否丟消息前先來了解一下什么是消息傳遞語義

刨根問底,Kafka消息中間件到底會不會丟消息
消息傳遞語義

message delivery semantic 也就是消息傳遞語義,簡單說就是消息傳遞過程中消息傳遞的保證性。主要分為三種:

  • at most once:最多一次。消息可能丟失也可能被處理,但最多只會被處理一次。
  • at least once:至少一次。消息不會丟失,但可能被處理多次。可能重復(fù),不會丟失。
  • exactly once:精確傳遞一次。消息被處理且只會被處理一次。不丟失不重復(fù)就一次。

理想情況下肯定是希望系統(tǒng)的消息傳遞是嚴(yán)格exactly once,也就是保證不丟失、只會被處理一次,但是很難做到。

回到主角Kafka,Kafka有三次消息傳遞的過程:

  1. 生產(chǎn)者發(fā)消息給Kafka Broker。
  2. Kafka Broker 消息同步和持久化
  3. Kafka Broker 將消息傳遞給消費者。

在這三步中每一步都有可能會丟失消息,下面詳細(xì)分析為什么會丟消息,如何最大限度避免丟失消息。

生產(chǎn)者丟失消息

先介紹一下生產(chǎn)者發(fā)送消息的一般流程(部分流程與具體配置項強(qiáng)相關(guān),這里先忽略):

  1. 生產(chǎn)者是與leader直接交互,所以先從集群獲取topic對應(yīng)分區(qū)的leader元數(shù)據(jù);
  2. 獲取到leader分區(qū)元數(shù)據(jù)后直接將消息發(fā)給過去;
  3. Kafka Broker對應(yīng)的leader分區(qū)收到消息后寫入文件持久化;
  4. Follower拉取Leader消息與Leader的數(shù)據(jù)保持一致;
  5. Follower消息拉取完畢需要給Leader回復(fù)ACK確認(rèn)消息;
  6. Kafka Leader和Follower分區(qū)同步完,Leader分區(qū)會給生產(chǎn)者回復(fù)ACK確認(rèn)消息。
刨根問底,Kafka消息中間件到底會不會丟消息
生產(chǎn)者發(fā)送數(shù)據(jù)流程

生產(chǎn)者采用push模式將數(shù)據(jù)發(fā)布到broker,每條消息追加到分區(qū)中,順序?qū)懭氪疟P。消息寫入Leader后,F(xiàn)ollower是主動與Leader進(jìn)行同步。

Kafka消息發(fā)送有兩種方式:同步(sync)和異步(async),默認(rèn)是同步方式,可通過producer.type屬性進(jìn)行配置。

Kafka通過配置request.required.acks屬性來確認(rèn)消息的生產(chǎn):

  • 0表示不進(jìn)行消息接收是否成功的確認(rèn);不能保證消息是否發(fā)送成功,生成環(huán)境基本不會用。
  • 1表示當(dāng)Leader接收成功時確認(rèn);只要Leader存活就可以保證不丟失,保證了吞吐量。
  • -1或者all表示Leader和Follower都接收成功時確認(rèn);可以最大限度保證消息不丟失,但是吞吐量低。

kafka producer 的參數(shù)acks 的默認(rèn)值為1,所以默認(rèn)的producer級別是at least once,并不能exactly once。

敲黑板了,這里可能會丟消息的!

  • 如果acks配置為0,發(fā)生網(wǎng)絡(luò)抖動消息丟了,生產(chǎn)者不校驗ACK自然就不知道丟了。
  • 如果acks配置為1保證leader不丟,但是如果leader掛了,恰好選了一個沒有ACK的follower,那也丟了。
  • all:保證leader和follower不丟,但是如果網(wǎng)絡(luò)擁塞,沒有收到ACK,會有重復(fù)發(fā)的問題。

Kafka Broker丟失消息

Kafka Broker 接收到數(shù)據(jù)后會將數(shù)據(jù)進(jìn)行持久化存儲,你以為是下面這樣的:

刨根問底,Kafka消息中間件到底會不會丟消息
消息持久化,無cache

沒想到是這樣的:

刨根問底,Kafka消息中間件到底會不會丟消息
消息持久化,有cache

操作系統(tǒng)本身有一層緩存,叫做 Page Cache,當(dāng)往磁盤文件寫入的時候,系統(tǒng)會先將數(shù)據(jù)流寫入緩存中,至于什么時候?qū)⒕彺娴臄?shù)據(jù)寫入文件中是由操作系統(tǒng)自行決定。

Kafka提供了一個參數(shù) producer.type 來控制是不是主動flush,如果Kafka寫入到mmap之后就立即 flush 然后再返回 Producer 叫同步 (sync);寫入mmap之后立即返回 Producer 不調(diào)用 flush 叫異步 (async)。

敲黑板了,這里可能會丟消息的!

Kafka通過多分區(qū)多副本機(jī)制中已經(jīng)能最大限度保證數(shù)據(jù)不會丟失,如果數(shù)據(jù)已經(jīng)寫入系統(tǒng) cache 中但是還沒來得及刷入磁盤,此時突然機(jī)器宕機(jī)或者掉電那就丟了,當(dāng)然這種情況很極端。

消費者丟失消息

消費者通過pull模式主動的去 kafka 集群拉取消息,與producer相同的是,消費者在拉取消息的時候也是找leader分區(qū)去拉取。

多個消費者可以組成一個消費者組(consumer group),每個消費者組都有一個組id。同一個消費組者的消費者可以消費同一topic下不同分區(qū)的數(shù)據(jù),但是不會出現(xiàn)多個消費者消費同一分區(qū)的數(shù)據(jù)。

刨根問底,Kafka消息中間件到底會不會丟消息

消費者群組消費消息

消費者消費的進(jìn)度通過offset保存在kafka集群的__consumer_offsets這個topic中。

消費消息的時候主要分為兩個階段:

1、標(biāo)識消息已被消費,commit offset坐標(biāo);

2、處理消息。

敲黑板了,這里可能會丟消息的!

場景一:先commit再處理消息。如果在處理消息的時候異常了,但是offset 已經(jīng)提交了,這條消息對于該消費者來說就是丟失了,再也不會消費到了。

場景二:先處理消息再commit。如果在commit之前發(fā)生異常,下次還會消費到該消息,重復(fù)消費的問題可以通過業(yè)務(wù)保證消息冪等性來解決。

總結(jié)

那么問題來了,kafka到底會不會丟消息?答案是:會!

Kafka可能會在三個階段丟失消息:

(1)生產(chǎn)者發(fā)送數(shù)據(jù);

(2)Kafka Broker 存儲數(shù)據(jù);

(3)消費者消費數(shù)據(jù);

在生產(chǎn)環(huán)境中嚴(yán)格做到exactly once其實是難的,同時也會犧牲效率和吞吐量,最佳實踐是業(yè)務(wù)側(cè)做好補(bǔ)償機(jī)制,萬一出現(xiàn)消息丟失可以兜底。

- END -

特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

刨根問底,Kafka消息中間件到底會不會丟消息

刨根問底,Kafka消息中間件到底會不會丟消息

刨根問底,Kafka消息中間件到底會不會丟消息

長按訂閱更多精彩▼

刨根問底,Kafka消息中間件到底會不會丟消息

如有收獲,點個在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉