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,性能会受到极大的影响.

相关推荐
greatonce1 分钟前
润米科技业财一体化升级:打破月结后45天对账瓶颈,入账效率提升70%,对账效率提升90%
大数据·科技
武子康11 分钟前
大数据-212 K-Means 聚类实战指南:从无监督概念到 Inertia、K 值选择与避坑
大数据·后端·机器学习
3***g20524 分钟前
Xshell高效运维实战技术文章大纲核心功能与应用场景
大数据
龙亘川34 分钟前
城管住建领域丨市政设施监测功能详解——桥梁运行监测系统(2)、管廊运维监测系统(3)
大数据·运维·人工智能·物联网·政务
2501_9209538641 分钟前
行业内比较好的6S管理咨询平台
大数据·运维·人工智能
上海乐备实生物44 分钟前
肝硬化生物标志物检测技术研究及应用进展
大数据·乐备实·labex·生物标志物·多因子检测·肝硬化·多重细胞因子检测
magic_kid_20101 小时前
Flink on YARN 依赖/JAR 包问题排查指南
flink·jar·包冲突
TDengine (老段)1 小时前
TDengine Go 语言连接器进阶指南
大数据·数据库·物联网·golang·时序数据库·tdengine·涛思数据
~央千澈~1 小时前
从阅文招聘JD看网文平台算法化-网文平台拥抱科技·卓伊凡
大数据·人工智能
房产中介行业研习社1 小时前
2026年1月房产中介管理系统哪家好用
大数据·人工智能