冪等生產者和事務生產者

Kafka消息交付

Kafka消息交付可靠性保障以及精確處理一次語義的實現。

所謂的消息交付可靠性保障,是指Kafka對Producer和Consumer要處理的消息提供什么樣的承諾。常見的承諾有以下三種:

最多一次(atmost once):消息可能會丟失,但絕不會被重復發送。

至少一次(at least once):消息不會丟失,但有可能被重復發送。

精確一次(exactly once):消息不會丟失,也不會被重復發送。

Kafka默認提供的交付可靠性保障是第二種,即至少一次。之前說過消息“已提交”的含義。即只有Broker成功“提交”消息且Producer接到Broker應答才會認為該消息成功發送,如果沒接到應答,則會重試,所以這會導致消息重復發送

冪等性(Idempotence)和事務(Transaction)

無論是至少一次還是最多一次,都不如精確一次。即使Producer端重復發送了相同的消 息,Broker端也能做到自動去重。在下游Consumer看來,消息依然只有一條。

Kafka的精確一次是通過兩種機制:冪等性(Idempotence)和事務(Transaction)。

冪等性Producer

Producer默認不是冪等性的,但我們可以創建冪等性Producer。僅需要設置一個參數即

// enable.idempotence被設置成true后,Producer自動升級成冪等性Producer
props.put(“enable.idempotence”, ture)
// 或者
props.put(ProducerConfig.ENABLE_IDEMPOTENCE_CONFIG, true)
冪等性Producer的作用范圍:

它只能保證單分區上的冪等性,即一個冪等性Producer能夠保證某個主題的一個分區上不出現重復消息,它無法實現多個分區的冪等性。其次,它只能實現單會話上的冪等性,不能實現跨會話的冪 等性。這里的會話,可以理解為Producer進程的一次運行。當重啟了Producer進程之后,這種冪等性保證就喪失了。

如果想實現多分區以及多會話上的消息無重復,應該使用事務(transaction)或者依賴事務型Producer。這也是冪等性Producer和事務型Producer的最大區別!

事務

Kafka的事務概念類似于我們熟知的數據庫提供的事務。Kafka對事務的支持,目前主要是在read committed隔離級別上做事情。它能保證多條消息原子性地寫入到目標分區,同時也能保證Consumer只能看到事務成功提交的消息。

事務型Producer

事務型Producer能夠保證將消息原子性地寫入到多個分區中。這批消息要么全部寫入成功,要么全部失敗。另外,事務型Producer也不懼進程的重啟。Producer重啟回來后,Kafka依然保證它們發送消息的精確一次處理。

設置事務型Producer的方法也很簡單,滿足兩個要求即可:

? ? ? ? * 和冪等性Producer一樣,開啟enable.idempotence = true

? ? ? ? * 設置Producer端參數transactional.id。最好為其設置一個有意義的名字。

還需要在Producer代碼中做一些調整

producer.initTransactions();
try {producer.beginTransaction();producer.send(record1);producer.send(record2);producer.commitTransaction();
} catch (KafkaException e) {producer.abortTransaction();
}

這段代碼能夠保證Record1Record2被當作一個事務統一提交到Kafka,要么它們全部提交成功,要么全部寫入失敗。實際上即使寫入失敗,Kafka也會把它們寫入到底層的日志中,也就是說Consumer還是會看到這些消息。

因此在Consumer端,讀取事務型Producer發送的消息也是需要一些變更的。修改起來也很簡單,設置isolation.level參數的值即可。當前這個參數有兩個取值:

1. read_uncommitted:這是默認值,表明Consumer能夠讀取到Kafka寫入的任何消息,不論事務型Producer提交事務還是終止事務,其寫入的消息都可以讀取。很顯然,如果你用了事務型Producer,那么對應的Consumer就不要使用這個值。

2. read_committed:表明Consumer只會讀取事務型Producer成功提交事務寫入的消息。當然了,它也能看到非事務型Producer寫入的所有消息。

總結:

冪等性Producer只能保證單分區、單會話上的消息冪等性;而 事務能夠保證跨分區、跨會話間的冪等性。從交付語義上來看,自然是事務型Producer能做的更多。

?但比起冪等性Producer,事務型Producer的性能要更差,在實際使用過程中,我們需要仔細評估引入事務的開銷,切不可無腦地啟用事務。

參考:11 | 無消息丟失配置怎么實現?-Kafka核心技術與實戰-極客時間 (geekbang.org)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/37013.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/37013.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/37013.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SpringBoot:SpringBoot 調用第三方接口的幾種方式

一、前言 在項目中調用第三方接口時,確實需要根據項目的技術棧、架構規范以及具體的業務需求來選擇最適合的調用方式。比如:RESTful API調用、Feign聲明式HTTP客戶端、Apache HttpClient等調用方式,每種方式都有其適用場景和優勢。下面我們就…

倉庫管理系統16--入庫管理

原創不易&#xff0c;打字不易&#xff0c;截圖不易&#xff0c;多多點贊&#xff0c;送人玫瑰&#xff0c;留有余香&#xff0c;財務自由明日實現。 1、創建物資入庫用戶控件 <UserControl x:Class"West.StoreMgr.View.InStoreView"xmlns"http://schema…

CAS自旋解析

CAS全稱CompareAndSwap(比較并交換)&#xff0c;是cpu的指令&#xff0c;調用時不涉及上下文的切換。Java中屬于樂觀鎖的一種&#xff0c;具體流程如下圖&#xff1a; 具體的實現使用的是Unsafe類去調用native修飾的compareAndSwap方法&#xff0c;4個字段分別是對象實例&#…

PTA—C語言期末復習(判斷題)

1. C語言程序是從源文件的第一條語句開始執行的 &#xff08;F&#xff09; 在 C 語言中&#xff0c;程序是從 main 函數開始執行的&#xff0c;而不是從源文件的第一條語句開始執行 2. 若變量定義為double x;&#xff0c;則x % 2是符合C語言語法的表達式 &#xff08;F&#…

通過nginx去除 api url前綴 并保持后面剩余的url不變向后臺請求

如 我前臺瀏覽器向后臺請求的接口是 http://127.0.0.1:5099/api/sample/sample/getbuttonlist 實際的請求接口傳向 http://192.168.3.71:5099/sample/sample/getbuttonlist 方法是向config中加入下面這樣一個server server {listen 5099;location /api/ {rewrite ^/a…

HTML流星雨

目錄 寫在前面 完整代碼 代碼分析 系列文章 寫在最后 寫在前面 歲月如梭&#xff0c;光陰似箭&#xff0c;不知不覺暑假就要來嘍&#xff0c;本期小編用HTML給大家手搓了一個炫酷的流星雨動畫&#xff0c;一起來看看吧。 完整代碼 <!DOCTYPE html> <html lang…

項目風險管理系統有哪些?分享11款主流項目管理系統

本文將分享11款主流項目管理系統&#xff1a;PingCode、Worktile、StandardFusion、MasterControl、ClickUp、SAI360、Netwrix Auditor、MetricStream、Wrike、Celoxis、Zoho Projects。 在項目管理中&#xff0c;風險管理不僅是一個挑戰&#xff0c;也是保證項目順利進行的關鍵…

探索Vim的文本處理能力:精通查找與替換

探索Vim的文本處理能力&#xff1a;精通查找與替換 Vim&#xff0c;作為Linux終端下的王牌文本編輯器&#xff0c;以其強大的功能和靈活性深受開發者和系統管理員的喜愛。在Vim中進行查找和替換是文本編輯中的一項基礎且重要的操作。本文將詳細解釋如何在Vim中執行查找和替換文…

Linux Redis 服務設置開機自啟動

文章目錄 前言一、準備工作二、操作步驟2.1 修改redis.conf文件2.2 創建啟動腳本2.3 設置redis 腳本權限2.4 設置開機啟動2.5 驗證 總結 前言 請各大網友尊重本人原創知識分享&#xff0c;謹記本人博客&#xff1a;南國以南i、 提示&#xff1a;以下是本篇文章正文內容&#x…

編程的難點在哪?是邏輯、算法,還是模塊、框架的掌握?

&#x1f446;點擊關注 回復『新人禮』獲取學習禮包&#x1f446; 很多新手程序員在一開始都是滿懷熱情地投入到編程的學習&#xff0c;但卻在學習過程中處處碰壁&#xff0c;導致放棄。 編程的難點在于邏輯、數學、算法&#xff0c;還是模塊、框架、接口的掌握&#xff1f;但…

idea Error running ‘Application‘

1、Error running ‘Application’ Error running ApplicationError running Application. Command line is too long.Shorten the command line via JAR manifest or via a classpath file and rerun.找到 .idea/libraies/workspace.xml 中的 PropertiesComponent 屬性&#…

Android InputDispatcher分發輸入事件

派發循環是指 InputDispatcher 不斷地派發隊列取出事件&#xff0c;尋找合適的窗口并進行發送的過程&#xff0c;是 InputDispatcher 線程的主要工作 事件發送循環是 InputDispatcher 通過 Connection 對象將事件發送給窗口&#xff0c;并接受其反饋的過程 InputDispatcher —…

Spring Boot跨域請求關鍵處理技術解析

Spring Boot跨域請求關鍵處理技術解析 在Web開發中&#xff0c;跨域請求是一個常見問題&#xff0c;尤其在微服務架構和前后端分離的開發模式中更為突出。Spring Boot作為一種流行的Java Web框架&#xff0c;提供了多種解決跨域請求的方法。本文將詳細解析Spring Boot中跨域請…

在 Qt 中設置 QMainWindow 的大小

問題描述 一位 Qt 新手提問&#xff0c;是否有辦法將 QMainWindow 的大小設置為用戶桌面大小的 70%。他嘗試過使用伸縮因子&#xff0c;但未成功。QWidget::setFixedSize 可以工作&#xff0c;但只能使用像素值。 解決方案 方案一&#xff1a;使用 QDesktopWidget 在 QMain…

大模型賦能全鏈路可觀測性:運維效能的革新之旅

目錄 全鏈路可觀測工程與大模型結合---提升運維效能 可觀測性&#xff08;Observability&#xff09;在IT系統中的應用及其重要性 統一建設可觀測數據 統一建設可觀測數據的策略與流程 全鏈路的構成和監控形態 云上的全鏈路可視方案 為什么一定是Copilot 大模型的Copilo…

mov和mp4區別是什么?蘋果的原創和時代的寵兒

在數字媒體領域&#xff0c;視頻格式的選擇往往決定了觀看體驗的質量和文件的兼容性。在眾多視頻格式中&#xff0c;MOV和MP4無疑是最具代表性的兩種&#xff0c;它們分別承載著蘋果和互聯網世界的技術革新與歷史變遷。本文將帶您穿越時間的長廊&#xff0c;探索MOV與MP4的發展…

A : 平面劃分

Description 一條直線可以把平面分成兩部分&#xff0c;兩條直線分成四部分。那么 n 條直線最多可以把平面分成幾部分&#xff1f; Input 多組數據&#xff0c;每組數據一個正整數 1≤&#xfffd;≤1000。 Output Sample #0 Input Copy 3 5 Output Copy 7 16 Hin…

區間DP——AcWing 320. 能量項鏈

區間DP 定義 區間動態規劃&#xff08;Interval Dynamic Programming&#xff09;&#xff0c;簡稱區間DP&#xff0c;是動態規劃領域的一個重要分支&#xff0c;專門用于解決涉及區間問題的最優化問題。這類問題通常需要在給定的一組區間上找到最優解&#xff0c;比如求解最…

福蘭農莊攜手越南NFC巨頭朱雀橋薇妮她百香果飲料,深化品質合作

近日&#xff0c;國內知名果汁品牌福蘭農莊成功與越南NFC行業領軍者朱雀橋建立深入合作關系。為了進一步提升產品品質和市場競爭力&#xff0c;福蘭農莊派遣專業團隊前往越南&#xff0c;深入VINUT百香果飲料的生產線&#xff0c;學習其從原料采購到產品上市的嚴格操作流程。 在…

IAR 常見報錯與實用小技巧(ZigBee)

一、報錯 1.未發現選擇目標 原因&#xff1a;硬件連接存在問題 解決方案&#xff1a;將數據線重新插拔或更換接口、數據線 2. 燒錄終止 原因&#xff1a;燒錄前未點擊仿真器復位按鈕 解決方案&#xff1a; 進行燒錄前點擊仿真器復位按鈕&#xff08;下載過程中不能按&#xff…