Kafka的Topic的partitions数目设置最佳实践

前言

翻译加整理~
How to choose the number of topics/partitions in a Kafka cluster

如何确定Topic需要多少个Partitions

一般情况是数据吞吐决定,这里的吞吐的单位是MB/s,这里暂时不考虑kafka服务端的单partition的吞吐瓶颈,而是考虑Producer和Consumer两端的吞吐

Producer

生产者的吞吐和以下几个配置有关:

  1. batching size
  2. compression codec
  3. acks
  4. replication factor

一般情况下,一个Producer的吞吐在10MB/s左右

Consumer

Consumer的吞吐和用户逻辑强相关,所以需要consumer的业务逻辑实现方来评估consumer的吞吐能力

确定partition数目

Given:

  1. p : producer throughput in MB/S
  2. c : consumer throughput in MB/s
  3. t : overall throughtput in MB/s

Result:

NumOfPartition = max(t/p, t/c)

动态增加Partitions

Partition是可以动态增加的,但是需要尽量在业务接入最初,对parttion数目做准确评估,因为不是所有的业务场景都适合做动态增加Partition数目操作。 对于Keyed messge, 可以配置消息会按照key的hash值做partition的路由,这也保证了相同的key的消息的消费是保序的。如果动态增加partition数目,可能会导致乱序问题。 对于这样的业务场景,一个安全的扩容方案是先停掉所有的producer, consumer全部消费完数据后,再做 add partition操作,然后在恢复producer的写入

partition数目过多带来的问题

  1. 增加open file handles
  2. 增加Broker宕机恢复时间
  3. 增加延迟

对每台Broker来说,partition的数目不应该超过 100 * (num of brokers in cluster) * (replication-factor), 对于个10台broker,replication-factor=2的集群,单机partition的数目不应该超过 2000个~

结论

确定Topic的一个合适的Partition数目很重要,太少了, producer或者consumer会出现读写平静,太多了,会引起其他问题

参考文章

How to choose the number of topics/partitions in a Kafka cluster

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景介绍 Kafka简介 Kafka是一种分布式的,基于发布/订阅的消息系统。主要设计目标如下: 以时间复杂度为O...
    高广超阅读 12,893评论 8 167
  • 本文转载自http://dataunion.org/?p=9307 背景介绍Kafka简介Kafka是一种分布式的...
    Bottle丶Fish阅读 5,505评论 0 34
  • 目标 高吞吐量来支持高容量的事件流处理 支持从离线系统加载数据 低延迟的消息系统 持久化 依赖文件系统,持久化到本...
    jiangmo阅读 1,345评论 0 4
  • 2018年11月16日 周五 晴 今天又到周五了,一周的课又上完了。下午放学后在店里待...
    糖果屋MM阅读 182评论 0 0
  • 2018.11.05-2018.11.07 关于昨天的事情,表示遗憾,我想变得有钱,不是因为我爱金钱,而是因为变得...
    曼本竹心llm不良帅阅读 215评论 0 0