搜索
搜 索
本版
文章
帖子
用户
图文精华
hadoop-2.6.0+zookeeper-3.4.6+hbase-1.0.0+hive-1.1.0完全分布 ...
首页
Portal
专题
BBS
面试
更多
登录
注册
用户组:游客
主题
帖子
云币
我的帖子
我的收藏
我的好友
我的勋章
设置
退出
导读
淘贴
博客
群组
社区VIP
APP下载
今日排行
本周排行
本周热帖
本月排行
本月热帖
会员排行
About云-梭伦科技
»
专题
›
技术学习(版主发帖区)
›
大数据学习
›
Flink
›
连载型
›
Flink源码之StreamOperator
0
0
0
分享
Flink源码之StreamOperator
hanyunsong
2020-8-10 18:25:09
发表于
连载型
[显示全部楼层]
只看大图
阅读模式
关闭右栏
0
2389
问题导读:
1.StreamOperator是什么接口?
2.AbstractStreamOperator是什么抽象实现类?
3.StreamOperator继承哪些接口?
上一篇:Flink源码阅读之任务提交与数据传递
https://www.aboutyun.com/forum.php?mod=viewthread&tid=29302
StreamOperator
StreamOperator是流式operators的基础接口,是任务执行过程中的实际处理类,其上层由StreamTask调用,下层调用用户所实现的具体方法,它的 实现类在创建算子处理数据时是实现OneInputStreamOperator或TwoInputStreamOperator接口中的一种,分别表示处理一个输入、两个输入的Operator, 在这两个接口中包含了processElement/processWatermark/processLatencyMarker方法。
OneInputStreamOperator实现类StreamMap、WindowOperator、KeyedProcessOperator等单流处理Operator,TwoInputStreamOperator实现 类CoStreamMap、KeyedCoProcessOperator、IntervalJoinOperator等多流处理Operator。StreamSource表示的source端的operator,既没有 实现OneInputStreamOperator接口也没有实现TwoInputStreamOperator接口,因为其就是流处理的源头,不需要接受输入。
AbstractStreamOperator是StreamOperator的基础抽象实现类,所有的operator都必须继承该抽象类,它为生命周期和属性方法提供了默认的实现。 AbstractUdfStreamOperator是继承AbstractStreamOperator的抽象实现类,其内部包含了userFunction,在Task的生命周期都会调用userFunction中 对应的方法。
StreamOperator层级结构如下图:
StreamOperator继承的接口有:
CheckpointListener接口,其中的notifyCheckpointComplete方法表示checkpoint完成后的回调函数;
KeyContext接口,当前key的切换,用于KeyedStream中state的key的设置;
Disposable接口,其中的dispose方法主要用于对象销毁和资源释放
Serializable序列化接口
列举一些常见的StreamOperator:
env.addSource对应StreamSource;
dataStream.map对应StreamMap;
dataStream.window对应WindowOperator;
dataStream.addSink对应StreamSink;
dataStream.keyBy(...).process对应KeyedProcessOperator;
AbstractStreamOperator和AbstractUdfStreamOperator
前面提到,AbstractStreamOperator是StreamOperator的基础抽象实现类,而AbstractUdfStreamOperator则是面向userFunction调用,接下来就 具体分析一下。它们用于初始化或者资源的释放等操作,其中大部分方法都是被StreamTask触发调用,从invoke方法作为入口分析:
1. initializeState状态初始化,会调用到StreamOperator的initializeState方法,初始化operatorStateBackend和keyedStateBackend状态后端, 定时器恢复初始化,对于keyedState来说会自动初始化恢复,但是operatorState则需要手动初始化恢复,所以在其继承的AbstractUdfStreamOperator会 调用userFunction的initializedState方法,前提条件是该userFunction必须实现CheckpointedFunction接口;
2. open初始化方法,在AbstractStreamOperator中是一个空实现,通常可以在userFunction重写open方法完成一些用户初始化工作;
3. run方法(最新版本中是mailboxProcessor.runMailboxLoop()方法),如果任务正常则一直会执行这个方法,根据收到的的不同数据类型调用AbstractStreamOperator的不同方法:
如果是watermark,会调用其processWatermark方法,做一些定时触发的判断与调用;
如果是LatencyMarker,表示的是一个延时标记,用于统计数据从source到下游operator的耗时,会调用processLatencyMarker方法,上报Histogram 类型的metric,默认关闭;
如果是StreamRecord,也就是需要处理的业务数据,首先会调用setKeyContextElement方法,用于切换KeyedStream类型的statebackend的当前key, 然后调用processElement具体的数据处理流程;
如果是CheckpointBarrier,表示的是需要进行checkpoint,首先会调用prepareSnapshotPreBarrier方法。在AbstractStreamOperator中是一个 空的实现,然后调用snapshotState方法。在AbstractUdfStreamOperator中会调用userFunction的snapshotState方法,前提是该userFunction必须 实现CheckpointedFunction接口;
4. close方法,任务正常结束调用的方法,在AbstractStreamOperator中是一个空的实现,通常可以在userFunction中重写close方法完成一些资源的 释放;
5. dispose方法,任务正常结束或异常结束调用的方法,异常结束时会调用close方法,正常结束不会重复调用close方法,在其中完成一些状态最终资源的 释放;
其它方法:
6. setup方法,初始化做一些参数的配置;
7. notifyCheckpointComplete方法,在checkpoint完成时调用的方法,面向用户实现的userFunction需要实现CheckpointListener接口.
加微信w3aboutyun,获取更多资源
领取100本书+1T资源
http://www.aboutyun.com/forum.php?mod=viewthread&tid=26480
大数据5个项目视频
http://www.aboutyun.com/forum.php?mod=viewthread&tid=25235
名企资源、名企面试题、最新BAT面试题、专题面试题等资源汇总
https://www.aboutyun.com/forum.php?mod=viewthread&tid=27732
文章作者:zlzhang0122
文章来源1:
https://github.com/zlzhang0122/f ... c/streamoperator.md
文章来源2:
https://github.com/zlzhang0122/f ... er/doc/jobsubmit.md
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
显身卡
没找到任何评论,期待你打破沉寂
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
发表新帖
hanyunsong
中级会员
关注
25
主题
48
帖子
4
粉丝
TA的主题
面试最新整理常问Spark知识点
2020-9-17
企业级数据仓库构建(八):搭建DWD 层-业务数据
2020-9-17
企业级数据仓库构建(五):数据仓库项目实战
2020-9-14
大数据分布式查询引擎Presto学习之路
2020-9-14
企业级数据仓库构建(三):数据采集模块环境搭建
2020-9-10
24小时热文
找工作很难,为什么我一天三个机会
股票魔法师.Ⅲ,趋势交易圆桌访谈
大数据面试题
我如何从股市赚了200万(珍藏版)
投资心理学(原书第5版) (华章经典&金融
关闭
推荐
/2
中文版ChatGPT
1.无需魔法 2.提高编程效率 3.提高文档能力
查看 »
新手帮助
新手帮助:注册遇到问题,领取资源,加入铁粉群,不会使用搜索,如何获取积分等
查看 »
意见
反馈