最常见的使用Timer的地方就是KeyedProcessFunction。我们在其processElement()方法中注册Timer,然后覆写其onTimer()方法作为Timer触发时的回调逻辑。根据时间特征的不同:
(1)处理时间——调用Context.timerService().registerProcessingTimeTimer()注册;onTimer()在系统时间戳达到Timer设定的时间戳时触发。
(2)事件时间——调用Context.timerService().registerEventTimeTimer()注册;onTimer()在Flink内部水印达到或超过Timer设定的时间戳时触发。
定时器原理
在Flink中,定时器是用于触发时间窗口操作的关键组件。当数据流进入Flink作业时,会根据时间戳进行排序,并根据时间窗口的规则将数据分组。定时器的作用是在每个时间窗口内的数据达到一定数量或一定时间后,触发相应的操作。
Flink中的定时器分为两种:基于事件时间的定时器和基于处理时间的定时器。基于事件时间的定时器根据事件本身的时间戳进行触发,而基于处理时间的定时器则根据Flink作业的处理时间进行触发。在实际应用中,基于事件时间的定时器更加精确,但在数据倾斜或网络延迟的情况下&#x
本文详细介绍了Flink中的定时器,包括处理时间和事件时间的定时器注册、原理及注意事项。定时器在KeyedProcessFunction中使用,通过Context.timerService()注册。处理时间定时器在系统时间达到设定时间时触发,事件时间定时器在水印超过设定时间时触发。Flink的定时器具有容错性,能与状态一起保存在Checkpoint中。
订阅专栏 解锁全文
381

被折叠的 条评论
为什么被折叠?



