Kafka-副本数量设置

1. ISR副本数量设置

指的是存活的副本数量

ISR 机制的另外一个相关参数是 min.insync.replicas , 可以在 broker 或者主题级别进行配置,代表 ISR 列表中至少要有几个可用副本。这里假设设置为 2,那么当可用副本数量小于该值时,就认为整个分区处于不可用状态。此时客户端再向分区写入数据时候就会抛出异常。

java 复制代码
org.apache.kafka.common.errors.NotEnoughReplicasExceptoin: Messages are rejected since there are fewer in-sync replicas than required。

2. 总副本数量设置

指的是一个分区的总的副本数量

2.1 新建主题时指定

Kafka 的主题被分为多个分区 ,分区是 Kafka 最基本的存储单位。每个分区可以有多个副本 (可以在创建主题时使用 replication-factor 参数进行指定)。其中一个副本是首领副本 (Leader replica),所有的事件都直接发送给首领副本;其他副本是跟随者副本 (Follower replica),需要通过复制来保持与首领副本数据一致,当首领副本不可用时,其中一个跟随者副本将成为新首领。

创建副本为2的topic

bash 复制代码
kafka-topics --zookeeper mdw:2181/kafka --create --replication-factor 2 --partitions 3 --topic test_topic

查看topic信息

bash 复制代码
kafka-topics --describe --zookeeper mdw:2181/kafka --topic test_topic

输出:
Topic:test_topic        PartitionCount:3        ReplicationFactor:2     Configs:
        Topic: test_topic       Partition: 0    Leader: 364     Replicas: 364   Isr: 364
        Topic: test_topic       Partition: 1    Leader: 365     Replicas: 365   Isr: 365
        Topic: test_topic       Partition: 2    Leader: 366     Replicas: 366   Isr: 366

2.2 通过配置文件配置

server.properties

bash 复制代码
offsets.topic.replication.factor=2
相关推荐
m0_751018661 小时前
fastapi celery flower rabbitmq redis 可运行demo
分布式·rabbitmq·fastapi
程序员小台4 小时前
Redis 高可用性:如何让你的缓存一直在线,稳定运行?
redis·分布式
娶个名字趴8 小时前
Rabbitmq运维
运维·分布式·rabbitmq
xtudj8 小时前
浅谈分布式多节点嵌入式系统中RS485总线指令冲突解决及性能优化
分布式·嵌入式·freertos·rs485通讯冲突检测·rs485通讯性能优化
蝉叫醒了夏天9 小时前
【后端开发核心技术全景解读:从云原生到分布式架构的深度实践】
分布式·云原生·架构
西域编娃9 小时前
Hadoop 集群部署与配置详解
大数据·linux·运维·hadoop·分布式
桂月二二10 小时前
云原生边缘计算:分布式智能的最后一公里革命
分布式·云原生·边缘计算
小二·12 小时前
深入理解分布式锁——以Redis为例
数据库·redis·分布式
Chen Jiacheng18 小时前
在 Spring Boot 2.7.x 中引入 Kafka-0.9 的实践
kafka·springboot·kafka0.9·springboot2.7.6
道法自然,人法天21 小时前
分布式事务管理:使用Seata简化微服务事务处理
分布式·微服务·架构