flink的计时器

背景

在flink中,我们经常使用ontimer计时器实现很多逻辑的功能,常见的比如某个传感器温度增加连续超过1分钟的告警输出等,本文就来简单记录下计时器的作用

计时器

ontimer的定义

java 复制代码
public void onTimer(long timestamp, OnTimerContext ctx, Collector<O> out)

timestamp: 触发定时器的事件/处理时间戳,这个时间是register定时器时指定的那个时间

ctx: 上下文对象,通过它可以访问水位线时间戳,处理时间时间戳,当前键值等

out:主输出,注意,ontimer定时器中也可以输出记录

基本上在定时器中我们能实现的逻辑和在process主逻辑中的一样

计时器局限性

我们只能在KeyedStream上,也就是键值分区数据流上注册计时器,如果你想要在DataStream上面使用,你需要首先把DataStream转换成KeyedStream,而转换的方式可以通过实现一个返回常数值的KeySelector来创建KeyedStream,但是一旦这样做,下游的算子的并行度相当于实际变成了1,性能会受到极大的影响.

相关推荐
张人玉41 分钟前
LiveCharts WPF MVVM 图表开发笔记
大数据·分布式·wpf·livecharts
建投数据1 小时前
建投数据再度获评国家级“高新技术企业”
大数据·人工智能
中电金信1 小时前
中电金信助力200+金融机构同步迁移SWIFT ISO20022标准
大数据·人工智能
山沐与山1 小时前
【Flink】Flink编程模型:DataStream与DataSet
大数据·flink
面向Google编程1 小时前
Flink源码阅读:如何生成ExecutionGraph
大数据·flink
飞凌嵌入式2 小时前
AIoT出海背景下,嵌入式主控的国际认证之路与价值思考
大数据·人工智能·嵌入式硬件·区块链·嵌入式
面向Google编程2 小时前
Flink源码阅读:状态管理
大数据·flink
面向Google编程2 小时前
Flink源码阅读:Checkpoint机制(下)
大数据·flink
WZGL12303 小时前
数字化模式全面赋能,“智能+养老”破题养老痛点
大数据·人工智能·科技·生活·智能家居