• 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.

  • 相关阅读:
    数据存储策略——lsm-tree
    让阿里P8都为之着迷的分布式核心原理解析到底讲了啥?看完我惊了
    Leetcode 01-算法入门与数组-④数组二分查找
    java基于ssm+jsp的高校失物招领系统 (代码+数据库+LW+调试)
    查看日志还在用tail -f ? 要不换 less +F 试试?
    jQuery easyui源码赏析
    Leetcode刷题笔记--Hot81--90
    使用newman来执行posman脚本
    html中css的基础学习
    flask---》response
  • 原文地址:https://blog.csdn.net/AnameJL/article/details/133794499