美文网首页
数据倾斜导致子任务积压

数据倾斜导致子任务积压

作者: 坨坨的大数据 | 来源:发表于2022-04-20 12:36 被阅读0次

业务背景:

一个流程中,有两个重要子任务:一是数据迁移,将kafka实时数据落Es,二是将kafka数据做窗口聚合落hbase,两个子任务接的是同一个Topic GroupId。上游Topic的 tps高峰达到5-6w。

问题描述:

给 24个 TaskManager(CPU) 都会出现来不及消费的情况。

问题原因:

做窗口聚合的任务的分组字段,分组粒度太小,hash不能打散,数据倾斜严重,导致少数TaskManager上压力过大,从而影响落Es的效率,导致背压。

解决方式:

将两个任务独立开来,作为不同的流程。

结果:

修改之前24个TaskManager(CPU) 来不及消费,改完之后20个CPU可完成任务。Kafka实时数据落Es的16个TaskManager,将kafka数据做窗口聚合落hbase的4个TaskManager。

另:

同样的数据、同样的Tps作为数据输入,Hbase的输出能力远超过Es,考虑实时任务落数据进Es要慎重。

Flink任务落Es时要考虑设置微批落数据,设置bulk.flush.max.actions和bulk.flush.interval.ms至合适值,否则影响吞吐量。

相关文章

网友评论

      本文标题:数据倾斜导致子任务积压

      本文链接:https://www.haomeiwen.com/subject/zsemertx.html