当前位置: 首页 > news >正文

kafka--基础知识点--5.4--max.in.flight.requests.per.connection

一、参数定义

max.in.flight.requests.per.connection 是 Kafka 生产者客户端配置参数,用于控制生产者与单个 Broker 连接中未确认请求的最大数量。简单来说,它限制了生产者在等待之前发送的消息确认(ACK)时,可以同时向同一个 Broker 发送的未完成请求数量。

二、核心作用

  1. 吞吐量与延迟的平衡

    • 高值(如 5):允许生产者并行发送多个请求,提高吞吐量,但可能增加延迟(因需要等待多个 ACK)。
    • 低值(如 1):确保消息按顺序发送和确认,降低吞吐量但保证顺序。
  2. 消息顺序保证

    • 当值 > 1 时,生产者可能并行发送消息,导致后续消息的 ACK 先于前序消息返回,破坏消息顺序。
    • 当值 = 1 时,生产者严格按顺序发送和确认消息,确保消息顺序与生产者发送顺序一致。

三、默认值与配置

1. 默认值

  • Kafka 原生客户端:默认值为 5
  • Confluent Kafka Python 客户端:默认值同样为 5(需确认具体版本,但通常与原生客户端一致)。

2. 配置示例(Python confluent_kafka)

from confluent_kafka import Producerproducer_config = {'bootstrap.servers': 'localhost:9092','max.in.flight.requests.per.connection': 1,  # 设置为 1 以保证顺序'acks': 'all','retries': 5,'enable.idempotence': True
}producer = Producer(producer_config)

四、关键影响场景

1. 幂等性(Idempotence)与事务(Transactions)

  • 幂等性启用时
    Kafka 会自动将 max.in.flight.requests.per.connection 设为 1,以确保消息顺序。若手动设置为更高值,可能导致幂等性失效。
  • 事务启用时
    必须显式设置 max.in.flight.requests.per.connection=1,以确保跨分区事务的原子性。

2. 消息顺序敏感型业务

  • 场景:如金融交易、日志审计等需要严格消息顺序的场景。
  • 配置建议
    producer_config['max.in.flight.requests.per.connection'] = 1
    

3. 高吞吐量场景

  • 场景:如实时日志采集、非关键业务数据传输。
  • 配置建议
    producer_config['max.in.flight.requests.per.connection'] = 5  # 使用默认值或更高
    

五、验证参数生效

1. 生产者日志验证

  • 启用调试日志:在生产者配置中添加 debug='producer'
  • 观察日志
    [2025-07-19 10:00:00,000] DEBUG Setting producer max.in.flight.requests.per.connection to 1 (kafka.producer.KafkaProducer)
    

2. 性能测试对比

  • 测试方法
    1. 发送 100 万条消息,分别设置 max.in.flight.requests.per.connection=1=5
    2. 测量吞吐量(消息/秒)和端到端延迟。
  • 预期结果
    • =5 时吞吐量更高,但延迟可能略高。
    • =1 时吞吐量较低,但消息顺序严格保证。

六、最佳实践总结

场景配置值说明
严格消息顺序1金融交易、日志审计等场景,确保消息顺序与发送顺序一致。
高吞吐量非顺序场景5实时日志、非关键业务数据,牺牲少量顺序性以换取更高吞吐量。
启用幂等性或事务1幂等性/事务需严格顺序保证,Kafka 会自动强制设置为 1

通过合理配置 max.in.flight.requests.per.connection,可在吞吐量、延迟和消息顺序之间找到最佳平衡。

http://www.dtcms.com/a/288750.html

相关文章:

  • 《计算机网络》实验报告五 DNS协议分析与测量
  • 网络(HTTP)
  • QT无边框窗口
  • 分享如何在Window系统的云服务器上部署网站及域名解析+SSL
  • kotlin 扩展函数 在链式调用的妙用
  • LINUX入门(二)QT的安装及运行环境搭建
  • jmeter如何做自动化接口测试?
  • 元宇宙经济的四个特征
  • Spring Boot中REST与gRPC并存架构设计与性能优化实践指南
  • Dify 1.6 安装与踩坑记录(Docker 方式)
  • LeetCode 198 打家劫舍 LeetCode 213.打家劫舍II
  • 华为开源自研AI框架昇思MindSpore应用案例:基于ERNIE模型实现对话情绪识别
  • [Python] -项目实战4- 利用Python进行Excel批量处理
  • 基于pyside6的通用机器人遥控控制界面
  • client-go: k8s选主
  • JAVA面试宝典 -《容灾设计:异地多活架构实践》
  • go-redis Pipeline 与事务
  • 民法学学习笔记(个人向) Part.1
  • 如何应对“躺平”文化对项目的冲击
  • 生物化学笔记:安全防护 射频和微波辐射防护 电磁辐射与防护 生物电磁学
  • 《镜语者》
  • 技术演进中的开发沉思-40 MFC系列:多线程协作
  • AI-Compass 前沿速览:ChatGPT Agent、Kimi2、Mistral 语音模型、Grok AI 情感陪伴、百度 Tizzy、有言数字人
  • java学习6--方法
  • 深入解析定点数移位运算:原理、规则与实例
  • Golang的微服务链路追踪
  • github 近期热门项目-2025.7.20
  • RabbitMQ面试精讲 Day 4:Queue属性与消息特性
  • 【图论】图的定义与一些常用术语
  • RabbitMQ:解锁高效消息传递的密码[特殊字符]