写点什么

LinkedIn 的工程师详述了生产环境下 Kafka 的调试和最佳实践

  • 2016-06-21
  • 本文字数:1359 字

    阅读完需:约 4 分钟

在本文中,LinkedIn 的软件工程师 Joel Koshy 详细阐述了他和一个工程师团队是如何解决生产环境下 Kafka 的两次事故的。这两次事故是由于多个产品缺陷、特殊的客户行为以及监控缺失的交错影响导致的。

第一个缺陷是在 LinkedIn 的变更请求跟踪系统中观察到的,部署平台认为这是从服务发出的重复邮件。Koshy 指出,其根本原因是由于消息格式的改变,和随后缓存加载在偏移管理器的终止,而这个偏移管理器已经被设置了一个旧的偏移量。由于这个主题分区上的低数据容量,日志压缩和清除触发器在部署的主题上从来没有被触发过。这导致一个旧的偏移量被当作消费者的起点,同时也使得以前已经消费过的消息被重新读取,并触发了重复的电子邮件。

第二个缺陷是在一个数据部署管道中,它里面的 Hadoop 推送作业器会发送数据到 Kafka 的非生产环境,然后通过 Kafka 集群复制到生产集群。在发现取回的偏移量没有有效检查点的时候,复制就被卡住了。它表明前一个检查的偏移量被丢掉了。Koshy 是这样描述根本原因的:

…由于日志压缩进程已经停止一段时间了,有几个较旧的偏移量仍然还在主题中。偏移缓存加载进程已经将它们加载到了缓存中。这本身是没有问题的,因为日志中更多的最新偏移量最终会覆盖那些旧的条目。问题出在旧偏移量的清除进程是在偏移加载的过程中开始的,偏移加载的过程需要较长的时间。旧条目清除之后会在日志末尾追加标记。而与此同时,偏移量的加载过程仍在进行,并会加载最近的偏移量到缓存中,但它只会在看到标记之后才会去除那些条目。这就解释了为什么偏移量实际上被丢失的原因。

Kafka 代理之间不清楚首席代理选举的规则,这会导致处于分区的首席代理在完成复制延迟过程中的失败会引起偏移量倒转。Kafka 消息的消费者发出读取指定偏移量的请求。消费者会对主题分区检查它们的偏移量,因此它们可以从最后一次检查点(消费者需要重启的点)重新开始。检查可以发生在很多时候,包括消费者失败、重启或者分区被加到主题里以及在消费者实例之间的分区分发规则需要改变的时候。如果一个消费者获取这个代理的主题日志之外的偏移关键字,它会收到 OffsetOutOfRange 的错误。消费者需要根据它们 auto.offset.reset 配置,来重新设置它们的偏移为最新或最早的有效偏移。

Koshy 指出,

重置为最早的偏移会引起重复消费,而重置为最新的偏移意味着可能会丢失在偏移复位和下一次读取之间已经到达的消息。

Koshy 还着重指出一些尽早发现偏移倒回的最佳实践,包括:通过监控集群中模糊不清的首席选举率,基于消费者延迟的监控和告警从而避免误报。监控日志压缩的指标(特别是最大脏读率传感器的),以及偏移管理的指标(如偏移缓存大小、提交率、组数传感器等)。偏移量自己被存在一个可复制、可分区、可压缩的日志中,它们与内部的 _consmer_offsets 主题相关联。Koshy 推荐在调试进程中尽早导出内部主题,从而避免日志压缩删除那些潜在有用的数据。特定的主题由消息组成,任何的时间偏移提交请求都会被发送到偏移管理代理中。在这种情况下,消费者和代理的日志也是可能有用的。

查看原文英文 LinkedIn Details Production Kafka Debugging and Best Practices


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-06-21 19:003921

评论

发布
暂无评论
发现更多内容

超全!GitHub星标6500的Python入门教程大全,太强了!

我再BUG界嘎嘎乱杀

Python 后端 入门 开发语言 零基础

2024年第二届服务韧性工程(SRE)论坛成功举办

雅菲奥朗

人工智能 大数据 运维 SRE 运维开发

2024第二届服务韧性工程(SRE)论坛分会场“人工智能驱动运维研发革命”成功举办

雅菲奥朗

人工智能 运维 大模型

服务韧性工程(SRE)论坛演讲实录 | 北京移动:云时代的多维协同智慧运维体系建设

雅菲奥朗

运维 SRE

前后端数据传输约定探讨

京东科技开发者

2024第二届服务韧性工程(SRE)论坛分会场“SRE助力出海企业构建健壮的IT生态系统”成功举办

雅菲奥朗

人工智能 运维 SRE 混沌工程 运维开发

数字化时代的数据管理:多样化数据库选型指南

京东科技开发者

Python中的7种基础数据类型,看这4500字就够了!

我再BUG界嘎嘎乱杀

Python 后端 基础 数据类型 开发语言

PostgreSQL 如何解决数据迁移过程中的数据类型不匹配问题?

程序员墨松

数据库 postgresql

数据库容灾 | MySQL MGR与阿里云PolarDB-X Paxos的深度对比

阿里云数据库开源

通过引入火山引擎“数据飞轮”,头部美图类APP找到下一个增长点

新消费日报

Altair携手奇瑞汽车,荣获2024世界人工智能大会“AI赋能新型工业化创新应用优秀案例”

Altair RapidMiner

人工智能 AI 仿真 世界人工智能大会 altair

融云入驻首个数字生态出海基地,加速构建数字经济出海创新生态

融云 RongCloud

使用mybatis切片实现数据权限控制

京东科技开发者

一文读懂!10款办公必备的AI合成PPT软件盘点!

彭宏豪95

人工智能 在线白板 办公软件 AIGC AI生成PPT

半小时速通Python爬虫!GitHub开源的Python爬虫入门教程

我再BUG界嘎嘎乱杀

Python 爬虫 入门 开发语言 零基础

企业智能之旅(1): 建立智能企业的战略蓝图并付诸行动

亚马逊云科技 (Amazon Web Services)

亚马逊云科技 生成式AI

淘宝天猫商品评论API接口:用户反馈实时分析,驱动电商增长

技术冰糖葫芦

API Explorer API 调试 API 文档 API 协议

[外企工程师经验]softwere engineering common issue and best practice

极客罗杰

企业智能之路(2): 着手进行企业智能的技术准备和实践

亚马逊云科技 (Amazon Web Services)

亚马逊云科技 生成式AI

LinkedIn的工程师详述了生产环境下Kafka的调试和最佳实践_DevOps & 平台工程_Dylan Raithel_InfoQ精选文章