Flink 定时器

最常见的使用Timer的地方就是KeyedProcessFunction。我们在其processElement()方法中注册Timer,然后覆写其onTimer()方法作为Timer触发时的回调逻辑。根据时间特征的不同:

(1)处理时间——调用Context.timerService().registerProcessingTimeTimer()注册;onTimer()在系统时间戳达到Timer设定的时间戳时触发。
(2)事件时间——调用Context.timerService().registerEventTimeTimer()注册;onTimer()在Flink内部水印达到或超过Timer设定的时间戳时触发。

定时器原理


在Flink中,定时器是用于触发时间窗口操作的关键组件。当数据流进入Flink作业时,会根据时间戳进行排序,并根据时间窗口的规则将数据分组。定时器的作用是在每个时间窗口内的数据达到一定数量或一定时间后,触发相应的操作。
Flink中的定时器分为两种:基于事件时间的定时器和基于处理时间的定时器。基于事件时间的定时器根据事件本身的时间戳进行触发,而基于处理时间的定时器则根据Flink作业的处理时间进行触发。在实际应用中,基于事件时间的定时器更加精确,但在数据倾斜或网络延迟的情况下,可能会导致定时器触发的不准确。因此,选择合适的定时器类型需要根据具体的应用场景来决定。

定时器可以对处理时间和事件时间的变化做一些处理。每次调用 processElement() 都可以获得一个 Context 对象,通过该对象可以访问元素的事件时间
戳以及 TimerSer

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jasen91

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值