Kafka如何保证消息不丢失

Kafka为了保证消息不丢失,采用了多种技术和配置来增强消息的持久化和可靠性。以下是一系列Kafka为保证消息不丢失而采取的措施:

  1. 持久化存储
    • Kafka将所有发布的消息持久化存储在磁盘上,而不是仅仅在内存中缓存。消息会被写入到日志文件中,这部分日志文件是落地存储的,即使服务器重启,消息也不会丢失。
  2. 副本和ISR(In-Sync Replicas)机制
    • Kafka的主题可以配置多个副本(partitions的副本),每个partition至少有一个Leader副本,其他副本是Follower副本。
    • Leader副本负责处理读写请求,Follower副本会不断从Leader同步数据,形成一个同步的ISR集合。
    • 在配置了合适的消息复制因子(replication.factor)后,只要 ISR 集合中的至少一个副本存活,就可以保证消息不丢失。
  3. 异步复制和同步提交
    • 默认情况下,Kafka producer在发送消息时可以选择异步或同步方式。如果想要确保消息不丢失,可以将acks参数设置为all-1,这样只有当所有ISR副本都接收到消息后,Kafka才会向producer返回确认信息。
  4. 幂等性(Idempotence)
    • Kafka 0.11版本开始支持producer的幂等性,开启后࿰
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值