Flink如何处理迟到数据?

在flink中进行窗口计算时,由于乱序流数据的问题,往往会出现迟到数据,迟到数据未参与所属窗口的计算会对计算结果的准确性产生影响,对此,Flink有如下三种方法来保障结果的准确性。

(1)水位线的延迟

对于乱序流数据,水位线可以设置延迟 Flink的Watermark水位线详解-CSDN博客,但一般不宜将延迟时间设置的过大,否则流处理的实时性将会大大降低。因此还是会有迟到数据。

(2)窗口允许处理迟到数据

当水位线到达窗口结束时间时,默认窗口会关闭,之后来的数据就会被丢弃了,因此可以延迟窗口的关闭时间 。具体而言:在设置了水位线延迟的基础上,大部分的迟到数据已经能够被正确处理了,因此水位线到达窗口结束时间时,先触发计算,得到一个近似正确的结果,但窗口不会关闭,之后每来一个迟到数据,就再触发窗口计算,不断修正计算结果并输出。这就类似lambda架构。可以通过对windowedStream(对datastream调用window分配窗口后就是windowedStream)调用allowedLateness方法设置等待时间。

(3)迟到数据放入窗口侧输出流

即使有了上述的双重保障,但由于窗口不能一直等待,总会关闭,最终还是可能会有丢失数据,这时候该怎么办呢?Flink还提供了一种解决方法:将窗口关闭之后到来的迟到数据收集到侧输出流,保证数据不丢失。之后获取侧输出流中的数据,判断所属窗口,手动对结果进行更行,保证最终结果一定时正确的。

具体实现时对windowedStream调用sideOutoutLateData()方法,传入一个输出标签OutputTag用来标记是迟到数据流即可。基于窗口处理完成之后的datastream调用getSideOutput方法,传入对应的OutputTag即可获取迟到数据流进行后续处理。

相关推荐
£菜鸟也有梦4 分钟前
Kafka进阶指南:从原理到实战
大数据·kafka
hellolianhua6 分钟前
wordcount在mapreduce的例子
大数据·mapreduce
时序数据说11 分钟前
IoTDB集群的一键启停功能详解
大数据·数据库·开源·时序数据库·iotdb
就不爱吃大米饭20 分钟前
Chrome代理IP配置教程常见方式附问题解答
大数据·人工智能·搜索引擎
庄小焱42 分钟前
数据治理域——数据同步设计
大数据·数据治理·数据同步·系统架构设计·大数据治理
成长之路5141 小时前
【更新】全国省市县-公开手机基站数据集(2006-2025.3)
大数据
心仪悦悦2 小时前
RDD的自定义分区器
大数据·分布式·spark
End9282 小时前
RDD的自定义分区器
大数据
数据库安全2 小时前
美创科技针对《银行保险机构数据安全管理办法》解读
大数据·人工智能·产品运营
ice___Cpu3 小时前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch