压测实操--kafka broker压测方案

作者:九月

环境信息:

操作系统centos7.9,kafka版本为hdp集群中的2.0版本。

kafka broker参数

num.replica.fetchers:副本抓取的相应参数,如果发生ISR频繁进出的情况或follower无法追上leader的情况则适当增加该值,但通常不要超过CPU核数+1;

num.io.threads:broker处理磁盘IO的线程数,主要进行磁盘io操作,高峰期可能有些io等待,因此配置需要大些,最好配置线程数量为cpu核数2倍,最大不超过3倍;

num.network.threads:broker处理消息的最大线程数,和我们生产消费的thread很类似主要处理网络io,读写缓冲区数据,基本没有io等待,最好配置线程数量为cpu核数加1;

num.replica.fetchers

集群中默认配置是1,调整该参数,观察吞吐速率。

调整num.replica.fetchers配置后,使用kafka-consumer-perf-test.sh脚本获取吞吐速率。

bash 复制代码
/usr/hdp/3.1.5.0-152/kafka/bin/kafka-consumer-perf-test.sh --broker-list 172.16.120.30:6667,172.16.120.36:6667,172.16.120.37:6667 --topic test_kafka_broker --messages 1000000 --fetch-size  1048576

num.io.threads

集群中默认配置是8,调整该参数,观察吞吐速率。

调整num.io.threads配置后,使用kafka-consumer-perf-test.sh脚本获取吞吐速率。

bash 复制代码
/usr/hdp/3.1.5.0-152/kafka/bin/kafka-consumer-perf-test.sh --broker-list 172.16.120.30:6667,172.16.120.36:6667,172.16.120.37:6667 --topic test_kafka_broker --messages 1000000 --fetch-size  1048576

num.network.threads

集群中默认配置是3,调整该参数,观察吞吐速率。

调整num.network.threads配置后,使用kafka-consumer-perf-test.sh脚本获取吞吐速率。

bash 复制代码
/usr/hdp/3.1.5.0-152/kafka/bin/kafka-consumer-perf-test.sh --broker-list 172.16.120.30:6667,172.16.120.36:6667,172.16.120.37:6667 --topic test_kafka_broker --messages 1000000 --fetch-size  1048576

总结

通过调整集群中kafka broker的参数配置,获取不同参数下的吞吐速率。对broker参数的优化应当结合集群主机中的硬件资源进行适当调整。通过调整测试获取最合适的参数配置。

更多技术信息请查看云掣官网https://yunche.pro/?t=yrgw

相关推荐
失散132 小时前
分布式专题——33 一台新机器进行Web页面请求的历程
分布式·tcp/ip·http·路由器·交换机
稚辉君.MCA_P8_Java6 小时前
kafka解决了什么问题?mmap 和sendfile
java·spring boot·分布式·kafka·kubernetes
沐浴露z7 小时前
分布式场景下防止【缓存击穿】的不同方案
redis·分布式·缓存·redission
zhuyasen7 小时前
让压测回归简单:体验 PerfTest 分布式模式的“开箱即用”
分布式·压力测试
森林猿7 小时前
docker-compose-kafka 4.1.0
docker·容器·kafka
jackaroo202010 小时前
后端_Redis 分布式锁实现指南
数据库·redis·分布式
00后程序员张10 小时前
RabbitMQ核心机制
java·大数据·分布式
爱吃烤鸡翅的酸菜鱼12 小时前
深度掌握 Git 分支体系:从基础操作到高级策略与实践案例
分布式·git·后端·gitee·github
yenggd14 小时前
vxlan-bgp-evnp分布式网关配置案例
网络·分布式·华为