聊聊kafka client性能调优及kafka最佳实践

这里是weihubeats ,觉得文章不错可以关注公众号小奏技术,文章首发。拒绝营销号,拒绝标题党

背景

最近在使用kafka的时候遇到了一些性能问题。

所以就打算研究下kafka相关的性能优化方案。

client主要分两个

  • producer
  • consumer

producer

producer主要是有两个核心参数

batch.size

先说说这个参数吧 batch.sizeproducer的参数。

当多条消息发送到相同分区时,producer就会将消息打包到一起,然后一次性批量发送到kafka。减少网络请求

默认到小是1638416kb

默认值其实是偏小的,所以我们最好设置为更大。

batch.size 设置的越大,吞吐就越大,但是延迟也会越大

linger.ms

我们设想一下,如果要发送的消息一直达不到我们的batch.size怎么办呢?

难道消息一直不发送吗?

这里就推出第二个参数linger.ms。表示batch的超时时间。

如果linger.ms时间内batch.size还没达到的话,消息也会直接发送。

该值越大,吞吐越大、但延迟也会越大

consumer

consumer这边的核心参数就是fetch.min.bytes,默认值是1kb

Kafka Broker端积只要积攒了1kb 的数据,就可以返回给 Consumer

然后就是一个fetch.max.wait.msproducerlinger.ms类似。指定broker最大等待时间,默认500ms

kafka最佳实践

实际早在国外Hortonworks就总结了一些kafka的最佳实践,虽然文章时间久远,但是依旧很有参考价值

总结

其实可以看到producerbatch.sizelinger.ms就是借鉴了tcp/ip的网络发送算法。

tcp/ipNagle算法大致的规则如下

  1. 如果包长度达到MSS,则允许发送
  2. 如果包含FIN,则允许发送
  3. 如果设置了TCP_NODELAY,则允许发送
  4. 未设置TCP_CORK选项时,若所有发出去的小数据包(包长度小于MSS)均被确认,则允许发送
  5. 上述条件都未满足,但发生了超时(一般为200ms),则立即发送。
vbnet 复制代码
if there is new data to send then
    if the window size ≥ MSS and available data is ≥ MSS then
        send complete MSS segment now
    else
        if there is unconfirmed data still in the pipe then
            enqueue data in the buffer until an acknowledge is received
        else
            send data immediately
        end if
    end if
end if

总得来说主要是四个参数

producer:

consumer:

实际还有很多参数也需要配置,在kafka最佳实践里面都有一些说明,这里就不过多介绍了

相关推荐
小信丶5 分钟前
@EnableMethodCache 注解详解:原理、应用场景与示例代码
java·spring boot·后端·spring
小二·12 分钟前
Go 语言系统编程与云原生开发实战(第8篇)消息队列实战:Kafka 事件驱动 × CQRS 架构 × 最终一致性(生产级落地)
云原生·golang·kafka
qq_297574678 小时前
【实战教程】SpringBoot 集成阿里云短信服务实现验证码发送
spring boot·后端·阿里云
韩立学长10 小时前
【开题答辩实录分享】以《智能大学宿舍管理系统的设计与实现》为例进行选题答辩实录分享
数据库·spring boot·后端
编码者卢布12 小时前
【Azure Storage Account】Azure Table Storage 跨区批量迁移方案
后端·python·flask
她说..15 小时前
策略模式+工厂模式实现审批流(面试问答版)
java·后端·spring·面试·springboot·策略模式·javaee
梦梦代码精15 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
李慕婉学姐16 小时前
【开题答辩过程】以《基于Spring Boot的疗养院理疗管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring boot·后端
tb_first16 小时前
SSM速通2
java·javascript·后端
一路向北⁢17 小时前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信