赞
踩
Apache Flink 的核心功能之一是窗口处理,它允许开发人员以基于时间或基于计数的方式分组和处理数据流。
窗口技术是一种根据某些标准将数据流划分为有限块(称为窗口)的技术。
窗口(Window)是处理无界流的关键所在。窗口可以将数据流装入大小有限的“桶”中,再对每个“桶”加以处理。
例如,您可以根据时间间隔(每 5 分钟)、事件计数(每 100 个事件)或会话边界(不活动间隙)定义窗口。
在每个窗口内,您可以对数据进行各种操作,如聚合(总和、平均、计数)、转换(映射、过滤、连接)或复杂的业务逻辑。
Flink中窗口并不是静态准备好的,而是动态创建——当有落在这个窗口区间范围的数据达到时,才创建对应的窗口。(事件驱动型)
Tumbling Window
)对滚动窗口是一种对数据流进行均匀切片的方式,窗口之间没有重叠,每个数据元素只能属于一个窗口。
这种窗口形式最简单,适用于需要固定大小窗口的场景,而且每个数据元素都会被准确地分配到一个唯一的窗口中。
eg. 实时统计:例如每5分钟统计一次用户在线人数,使用5分钟的滚动窗口来进行累加计算。
固定的大小:滚动窗口有固定的窗口大小,例如每5分钟一个窗口。
无重叠:不同于滑动窗口,滚动窗口之间没有重叠部分。
首尾相接:窗口是连续的,每个窗口的开始和结束时间是紧密相连的,便于实现时间段内数据的精确统计。
唯一归属:每个数据元素只能属于一个窗口,不会被分配到多个窗口中。
Sliding Window
)定义滑动窗口的参数有两个:除去窗口大小(window size)之外,还有一个“滑动步长”(window slide)它其实就代表了窗口计算的频率。
窗口在结束时间触发计算输出结果,那么滑动步长就代表了计算频率
当滑动步长小于窗口大小时,滑动窗口就会出现重叠,这时数据也可能会被同时分配到多个窗口中。而具体的个数就由窗口大小和滑动步长的比值(size/slide)来决定。
滑动窗口 vs 滚动窗口:
窗口关系:
数据分配:
适用场景:
Session Window
)会话窗口根据数据元素的到达时间来动态定义窗口边界,而不是固定的时间间隔。这些窗口根据数据之间的会话超时时间(session timeout)来确定。
如果相邻两个数据元素的到达时间间隔小于设定的超时时间(size),它们被视为属于同一个会话窗口。超过超时时间的数据则被视为新的会话开始。
会话窗口的长度和位置是动态的,取决于数据元素到达的时间模式。因此,起始和结束时间是不确定的,窗口的边界会根据数据的到达时间自动调整。
不同会话窗口之间是不会重叠的,每个会话窗口都会有一定的间隔(session gap),保证相邻的会话窗口不会重叠。
Global Window
)全局有效性:
没有固定结束时间:
触发器的自定义需求:
eg:
假设有一个实时数据流,需要计算每个用户的累计点击次数,但不想每隔固定时间进行计算,而是希望在某个用户的点击次数达到一定数量时立即计算。这时可以使用全局窗口和相应的触发器来实现:
窗口化对于流处理至关重要,因为它使我们能够处理两个主要挑战:无限数据和无序数据。
与批处理不同,批处理有一组固定且有限的数据要处理,而流处理处理的是连续到达的无限数据。这意味着我们不能等待所有数据到达后再处理它,因为我们永远不会完成。
相反,我们需要在数据到达时以增量方式处理数据,并产生部分或近似结果。窗口化通过将流分解为可以独立处理的可管理块来帮助我们做到这一点。
流处理的另一个挑战是数据可能无序到达,这意味着事件可能与其时间戳不一致。这可能是由于网络延迟、时钟偏差或其他原因造成的。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。