flink学习笔记-Window那些事

说明:本文为《Flink大数据项目实战》学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程:

Flink大数据项目实战:http://t.cn/EJtKcD1


1.Window是啥


1.1啥是Window?有啥作用?

Flink认为 Batch 是 Streaming 的一个特例,所以 Flink 底层引擎是一个流式引擎,在上面实现了流处理和批处理。而窗口(window)就是从 Streaming 到 Batch 的一个桥梁。Flink 提供了非常完善的窗口机制,这是Flink 最大的亮点之一(其他的亮点包括消息乱序处理,和 checkpoint 机制)。


Window是一种切割无限数据集为有限块并进行相应计算的处理手段(跟keyBy一样,也是一种分组手段,只不过同一event可能被分到多个组)。


在流处理应用中,数据是连续不断的,因此我们不可能等到所有数据都到了才开始处理。当然我们可以每来一个消息就处理一次,但是有时我们需要做一些聚合类的处理,例如:在过去的1分钟内有多少用户点击了我们的网页。在这种情况下,我们必须定义一个窗口,用来收集最近一分钟内的数据,并对这个窗口内的数据进行计算。

1.2Window分类(是否kyBy决定了大分类)

Keyed Windows(在已经按照key分组的基础上(KeyedStream),再构建多任务并行window)。


Non-Keyed Windows(在未分组的DataStream上构建单任务window,并行度是1,API都带All后缀)



1.3Keyed Windows vs Non-Keyed Windows(以基于time的window为例)


1.4Window的生命周期

创建:当属于该窗口的第一个元素到达时就会创建该窗口


销毁:当时间(event/process time)超过窗口的结束时间戳+用户指定的延迟时(allowedLateness(<time>)),窗口将被移除(仅限time-based window)

例如:对于一个每5分钟创建Tumbling Windows(即翻滚窗口)窗口,允许1分钟的时延,Flink将会在12:00到12:05这段时间内第一个元素到达时创建窗口,当watermark超过12:06时,该窗口将被移除


Trigger(触发器):指定了窗口函数在什么条件下可被触发,触发器还可以决定在创建和删除窗口之间的任何时间清除窗口的内容。在这种情况下,清除仅限于窗口中的元素,而不是窗口元数据。这意味着新数据仍然可以添加到该窗口中。

例如:当窗口中的元素个数超过4个时“ 或者 ”当水印达到窗口的边界时“触发计算。


Window的函数:函数里定义了应用于窗口(Window)内容的计算逻辑。


Evictor(驱逐者):将在触发器触发之后或者在函数被应用前后,清除窗口中的元素。

2.窗口分配器(Window Assingers)


2.1Window Assinger是干啥的

当你决定stream是否keyby之后,window是没有构建的,你还需要指定一个window Assinger用于定义元素如何分配到窗口中。


window Assinger如何指定?

1.Keyedstream:window(WindowAssigner)

2.non-keyed streams:windowAll(WindowAssigner)


window Assinger的作用:负责将每个传入的元素分配给一个或多个窗口。

2.2Window小分类(Window Assinger类型)

有了window Assinger,才会创建出各种形式的window来覆盖我们所需的各种场景,所以不用过多关注window本身的分类,关注window Assinger的分类即可。


Count-based window:根据元素个数对数据流进行分组切片

1.Tumbling CountWindow

2.Sliding CountWindow


Time-based window :根据时间对数据流进行分组切片

1.Tumbling Window

2.Sliding Window

3.Session Window


注意:Time-based window [start,end)

Times


2.3Tumbling Windows-翻滚窗口

定义:将数据依据固定的窗口长度对数据进行切片。


特点:

1.时间对齐

2.窗口长度固定

3.event无重叠


适用场景:BI统计(计算各个时间段的指标)。



对齐方式:默认是aligned with epoch(整点、整分、整秒等),可以通过offset参数改变对齐方式。


2.4Sliding Windows-滑动窗口

定义:是固定窗口的更广义的一种形式。滑动窗口由固定的窗口长度和滑动间隔组成。

特点:

1.时间对齐

2.窗口长度固定

3.event有重叠


适用场景:监控场景,对最近一个时间段内的统计(求某接口最近5min的失败率来决定是否要报警)。


对齐方式:默认是aligned with epoch(整点、整分、整秒等),可以通过offset参数改变对齐方式。


2.5Session Windows

定义:类似于web应用 的session,即一段时间没有接受到新数据就会生成新的窗口(固定gap/gap fun)。


特点:

1.时间无对齐

2.event不重叠

3.没有固定开始和结束时间


适用场景:线上用户行为分析。


Gap

1.固定gap

2.动态gap:实现SessionWindowTimeGapExtractor


特殊处理方式

1.session window operator为每个到达的event创建一个新窗口,如果它们之间的距离比定义的间隔更近,则将窗口合并在一起。

2.为了能够合并, session window operator需要合并触发器和合并窗口函数,例如ReduceFunction、AggregateFunction或ProcessWindowFunction

(FoldFunction不能合并)。


2.6Global Windows

定义:有相同key的所有元素分配给相同的单个全局窗口,必须指定自定义触发器否则没有任何意义。

注意:不要跟Non-keyed Window搞混,两个不同的角度。

使用方式:



2.7所有窗口盘点



2.8预定义Keyed Windows

Tumbling time window

.timeWindow(Time.seconds(30))


Sliding time window

.timeWindow(Time.seconds(30), Time.seconds(10))


Tumbling count window

.countWindow(1000)


Sliding count window

.countWindow(1000, 10)


Session window

.window(SessionWindows.withGap(Time.minutes(10)))

2.9预定义Non-Keyed Windows

Tumbling time window

.timeWindowAll(Time.seconds(30))


Sliding time window

.timeWindowAll(Time.seconds(30), Time.seconds(10))


Tumbling count window

.countWindowAll(1000)


Sliding count window

.countWindowAll(1000, 10)


Session window

.window(SessionWindows.withGap(Time.minutes(10)))


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容