码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Kafka学习笔记之进阶篇


    Kafka 消息幂等性

    enable.idempotence=true。设置了这个参数后,Producer自动升级成幂等性Producer。
    两个重要机制:
    1、Producer Id,幂等性的生产者每个客户端都有一个唯一编号id。
    2、sequence number,幂等性的生产者发送的每条消息都会带相应的sequence number,Server端就是根据这个值来判断数据是否重复。如果发现sequence number比服务端已经记录的要小,那么说明数据已经重复了。
    这个sequence number并不是全局有序的,不能保证所有时间上的幂等。它的作用范围有限。
    1、 只能保证单分区上的幂等性,一个幂等性Producer能够保证某个Topic的一个分区上不出现重复。
    2、 只能实现单会话上的幂等性,这里指Producer进程的一次运行,当重启了Producer进程后,幂等性不保证。

    分布式事务

    1、 因为生产者的消息可能跨分区,所以这里的事务是属于分布式事务。分布式事务的实现方式有很多,kafka选择了最常见的两阶段提交(2PC)。如果大家都可以commit,那就commit,否则就abort。
    2、 既然是2pc,那么就一定有一个协调者的角色,叫做Transaction Coordinator。
    3、 事务管理必须有事务日志,来记录事务的状态,以便Coordinator在意外挂掉之后继续处理原来的事务。跟消费者offset的存储一样,kafka使用了一个特殊的topic_transcation_state来记录事务状态。
    4、 如果生产者挂了,事务要在重启后可以继续处理,接着处理之前未处理完的事务,或者在其他机器上处理,必须有一个全局的唯一ID,这个就是transaction.id。配置了transaction.id,enable.idempotence会被设置为true。事务id相同的生产者,可以接着处理原来的事务。
    分布式事务流程图

    步骤:
    1、 生产者通过initTransactions API向Coordinator注册事务id。
    2、 Coordinator记录事务日志。
    3、 生产者把消息写入目标分区。
    4、 分区和Coordinator交互。当事务完成后,消息的状态应该是已提交,这样消费者才可以消费到。

  • 相关阅读:
    沁恒 CH32V208(五): CH32V208 运行FreeRTOS示例的说明
    全景解析 Partisia Blockchain:以用户为中心的全新数字经济网络
    CCF CSP题解:坐标变换(其一)(202309-1)
    Java8 stream处理List,Map总结
    慕思股份深交所上市:靠床垫和“洋老头”走红 市值224亿
    欧奈尔RPS曲线的编制方法及常见问题解答
    CDGA|工业互联网行业怎么做好数据治理?
    时间复杂度、空间复杂度 O(1)和 O(logN)
    攻防演练-组织沙盘推演的4个阶段.
    IronSource 聚合广告平台接入踩坑日记——游戏声音消失
  • 原文地址:https://blog.csdn.net/u012663412/article/details/127729848
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号