java时间触发器_java—如何实现一个Flink事件时间触发器,该触发器在X分钟内未收到任何事件后发出...

我正在努力理解Flink触发器是如何 job 的。我的数据流包含具有基于该sessionId聚合的sessionId的事件。每个会话都将包含一个已开始和一个结束事件,但是有时结束的事件将丢失。

为了处理这个问题,我设置了一个触发器,它将在处理结束事件时发出聚合会话。但是,如果2分钟内没有事件从该会话到达,我想发出我们迄今为止聚合的任何内容(我们发送事件的应用程序每分钟发送一次心跳,因此如果我们没有收到任何事件,则认为会话丢失)。

我设置了以下触发器函数:

public class EventTimeProcessingTimeTrigger extends Trigger {

private final long sessionTimeout;

private long lastSetTimer;

// Max session length set to 1 day

public static final long MAX_SESSION_LENGTH = 1000l * 86400l;

// End session events

private static ImmutableSet<String> endSession = ImmutableSet.<String>builder()

.add("Playback.Aborted")

.add("Playback.Completed")

.add("Playback.Error")

.add("Playback.StartAirplay")

.add("Playback.StartCasting")

.build();

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值