设为首页 收藏本站
查看: 1220|回复: 0

[经验分享] 与apache Kafka的一次语义

[复制链接]

尚未签到

发表于 2019-1-31 10:36:02 | 显示全部楼层 |阅读模式
  卡夫卡的“一次语义学”是在最近推出的版本中引入的,它使消息能够准确地传递给最终消费者一次,即使生产者试图发送消息。
  这一重大发布在社区中引起了许多人的注意,因为人们认为在分布式系统中这在数学上是不可能的。合流公司的联合创始人,阿帕奇卡夫卡的共同创建者杰伊克雷普斯解释了它的可能性,以及它是如何在卡夫卡实现的。岗.
  在这个博客中,我们将讨论如何利用卡夫卡提供的一次消息语义。
  ApacheKafka提供的不同消息传递语义综述
  “最多一次-m要旨可能会丢失,但永远不会重来。“
  在这种情况下,当ACK超时或返回错误时,生产者不会重试发送消息,因此消息可能最终不会写入Kafka主题,因此不会传递给使用者。
  "至少有一次-消息永远不会丢失,但可能会被重新传递。"
  在这种情况下,如果ACK超时或收到错误,生产者试图重新发送消息,假设消息没有写入Kafka主题。
  " 一次—  这是人们真正想要的,每条信息只传递一次。"
  在这种情况下,即使生产者试图重新发送消息,它也会导致消息被准确地传递一次给最终使用者。
  准确地说,一次语义是最理想的保证,并且需要消息传递系统本身与生成和使用消息的应用程序之间的协作。
  例如,如果在成功地使用了一条消息之后,您将您的Kafka使用者倒带到以前的偏移量,那么您将再次收到来自该偏移量的所有消息到最新的偏移量。这说明了为什么消息传递系统和客户端应用程序必须合作,以使语义发生精确一次。
  为什么要用卡夫卡的一次语义学?
  我们知道,至少一次保证每条消息至少保存一次,而不会丢失任何数据,但这可能会导致流中的重复。
  例如,如果代理在发送ACK之前失败,但是在消息成功地写入Kafka主题之后,此重试将导致消息被写入两次,从而多次传递给最终使用者。
  在新的完全一次语义学中,卡夫卡的处理语义保证了消息准确地传递给最终消费者一次。通过采取以下措施加强了这一点:
  Idempate生产者
  原子事务
  幂等生产者
  阿幂等操作是一种可以多次执行的操作,而不会产生与只执行一次操作不同的效果。
  现在,在Kafka中,生产者发送的操作可以是幂等的,因此,如果发生错误导致生产者重试,生产者多次发送的相同消息将只被写入维护的Kafka Broker上的日志一次。
  幂等生成器确保消息在单个生成器的生存期内准确地传递到特定的主题分区。
  要打开此特性并获得准确的每个分区一次语义-意味着不存在重复、数据丢失和顺序语义-请使用以下属性配置您的生产者:
  enable.idempotence=true
  打开此功能后,每个生产者都会得到一个唯一的id(PID),并将每条消息与序列号一起发送。当代理或连接失败,并且生产者试图重新发送消息时,只有当该消息的序列号比最后一条消息多一个时,它才会被接受。
  但是,如果生产者失败并重新启动,它将得到一个新的PID。因此,幂等性仅为单一生产者会议.
  原子事务
  Kafka现在通过新的事务API支持跨多个分区的原子写入。这允许生产者向多个分区发送一批消息,这样,批处理中的所有消息对所有使用者都是可见的,或者对任何使用者都是不可见的。
  它允许您在同一个事务中提交您的使用者抵消和您处理过的数据,从而允许端到端精确地一次语义。
  下面是一个示例片段,描述如何使用新的生产者API将消息原子地发送到一组主题分区:
  {
  producer.initTransactions();
  try{
  producer.beginTransaction();
  producer.send(record0);
  producer.send(record1);
  producer.sendOffsetsToTxn(…);
  producer.commitTransaction();
  } catch( ProducerFencedException e) {
  producer.close();
  } catch( KafkaException e ) {
  producer.abortTransaction();
  }
  }
  消费者
  若要使用事务,需要将使用者配置为使用以下权限孤立无援并使用新的生产者API。卡夫卡消费者现在有两个新的隔离级别:
  读承诺:在提交事务后读取两种类型的消息(那些不是事务的一部分并且是事务的消息)。
  读未承诺:按偏移顺序读取所有邮件,而不等待事务提交。此选项类似于卡夫卡消费者当前的语义。
  此外,transactional.id属性必须设置为生产者配置中的唯一ID。需要这个唯一的ID来提供跨应用程序重新启动的事务状态的连续性。
  参考文献
  CONFLUENT关于同一语义的博客
  Apache Kafka中的事务
  图像源比较至少一次语义的有利和消失的情况


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-669952-1-1.html 上篇帖子: Kafka 入门教程之一: 安装 下篇帖子: 在Windows下Kafka的基本配置及简单使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表