• Flink之窗口指派API模板


    flink中窗口指派主要分为两类NoKeyed WindowsKeyed Windows,这里就结合这两类阐述窗口指派API

    • NoKeyed Windows
      NoKeyed Windows同时又分为两类Porcessing TimeEvent Time,即处理时间语义和事件时间语义.
      1. 事件时间语义
        // 事件时间语义-滚动窗口
        source.windowAll(TumblingEventTimeWindows.of(Time.seconds(1)));
        // 事件时间语义-滑动窗口(参数1:窗口长度 参数2:滑动步长,计算频率)
        source.windowAll(SlidingEventTimeWindows.of(Time.seconds(5), Time.seconds(1)));
        // 事件时间语义-会话窗口-静态gap
        source.windowAll(EventTimeSessionWindows.withGap(Time.seconds(1)));
        // 事件时间语义-会话窗口-动态获取gap
        source.windowAll(EventTimeSessionWindows.withDynamicGap(element -> {...}));
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
      2. 处理时间语义
        // 处理时间语义-滚动窗口
        source.windowAll(TumblingProcessingTimeWindows.of(Time.seconds(1)));
        // 处理时间语义-滑动窗口(参数1:窗口长度 参数2:滑动步长,计算频率)
        source.windowAll(SlidingProcessingTimeWindows.of(Time.seconds(5), Time.seconds(1)));
        // 处理时间语义-会话窗口-静态gap
        source.windowAll(ProcessingTimeSessionWindows.withGap(Time.seconds(1)));
        // 处理时间语义-会话窗口-动态获取gap
        source.windowAll(ProcessingTimeSessionWindows.withDynamicGap(element -> {...}));
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
    • Keyed Windows
      同样Keyed Windows也分为Porcessing TimeEvent Time.
      1. 事件时间语义
        // 事件时间语义-滚动窗口
        keyedStream.window(TumblingEventTimeWindows.of(Time.seconds(1)));
        // 事件时间语义-滑动窗口(参数1:窗口长度 参数2:滑动步长,计算频率)
        keyedStream.window(SlidingEventTimeWindows.of(Time.seconds(5), Time.seconds(1)));
        // 事件时间语义-会话窗口-静态gap
        keyedStream.window(EventTimeSessionWindows.withGap(Time.seconds(1)));
        // 事件时间语义-会话窗口-动态获取gap
        keyedStream.window(EventTimeSessionWindows.withDynamicGap(element -> {...}));
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
      2. 处理时间语义
        // 处理时间语义-滚动窗口
        keyedStream.window(TumblingProcessingTimeWindows.of(Time.seconds(1)));
        // 处理时间语义-滑动窗口(参数1:窗口长度 参数2:滑动步长,计算频率)
        keyedStream.window(SlidingProcessingTimeWindows.of(Time.seconds(5), Time.seconds(1)));
        // 处理时间语义-会话窗口-静态gap5
        keyedStream.window(ProcessingTimeSessionWindows.withGap(Time.seconds(1)));
        // 处理时间语义-会话窗口-动态获取gap
        keyedStream.window(ProcessingTimeSessionWindows.withDynamicGap(element -> {...}));
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8

    窗口指派的API模板基本就这些内容,这里都是以时间窗口作为示例的,还有根据数据条数窗口的指派,窗口指派和时间窗口是一样的,只不过将keyedStream.window更换成countWindow.

  • 相关阅读:
    【DZBS-202/T低电流启动中间继电器】
    开源ESP32智能小车机械臂控制板Baize_Carboard(支持mixly)
    【Azure】解析 Microsoft Defender for Cloud:云安全的保护与管理
    Banana Pi BPI-R3 Mini 开源路由器,也能拍出艺术美感
    【一、虚拟机vmware安装】
    java运行linux命令时报错
    Go语言学习笔记—golang操作MongoDB数据库
    基于Git和Nginx搭建自己的私人图床,告别图片404
    MySQL基础篇总结
    ClickHouse SQL操作
  • 原文地址:https://blog.csdn.net/AnameJL/article/details/133794499