【Flink精讲】Flink任务调度机制

Graph 的概念

Flink 中的执行图可以分成四层: StreamGraph -> JobGraph -> ExecutionGraph -> 物理执

行图。

  • StreamGraph:是根据用户通过 Stream API 编写的代码生成的最初的图。用来表示程序的拓扑结构。
  • JobGraph: StreamGraph 经过优化后生成了 JobGraph,提交给 JobManager 的数据结构。主要的优化为,将多个符合条件的节点 chain 在一起作为一个节点,这样可以减少数据在节点之间流动所需要的序列化/反序列化/传输消耗。
  • ExecutionGraph: JobManager 根据 JobGraph 生成 ExecutionGraph。 ExecutionGraph 是JobGraph 的并行化版本,是调度层最核心的数据结构。
  • 物 理 执 行 图 : JobManager 根据 ExecutionGraph 对 Job 进行调度后,在各个TaskManager 上部署 Task 后形成的"图",并不是一个具体的数据结构。

WordCount举例

java 复制代码
public static void main(String[] args) throws Exception {
// 检查输入
final ParameterTool params = ParameterTool.fromArgs(args);
...
// set up the execution environment
final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
// get input data
DataStream<String> text =
env.socketTextStream(params.get("hostname"), params.getInt("port"), '\n', 0);
DataStream<Tuple2<String, Integer>> counts =
// split up the lines in pairs (2-tuples) containing: (word,1)
text.flatMap(new Tokenizer())
// group by the tuple field "0" and sum up tuple field "1"
.keyBy(0)
.sum(1);
counts.print();
// execute program
env.execute("WordCount from SocketTextStream Example");
}

StreamGraph在Client生成

分区器

JobGraph在Client生成

ExecutionGraph在JobManager生成

相关推荐
captain_AIouo41 分钟前
Captain AI打造OZON全员协同智能工具
大数据·人工智能·经验分享·aigc
杰建云1671 小时前
商家小程序有什么用
大数据·apache
财经资讯数据_灵砚智能1 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月11日
大数据·人工智能·python·信息可视化·自然语言处理
2501_934440231 小时前
只做中外合作办学,并且把它做深、做精
大数据·人工智能
国强_dev2 小时前
如何提升canal吞吐量
java·大数据·python
派拉软件2 小时前
AI 网关:重塑企业级大模型服务治理架构
大数据·人工智能·架构
Lucky me.2 小时前
Cloud code完整命令手册
大数据·elasticsearch·搜索引擎
大大大大晴天️2 小时前
Flink:Keyed State vs Operator State 原理与实践
大数据·flink
万岳科技程序员小金3 小时前
大健康私域直播APP开发解决方案:电商直播带货系统源码功能解析
大数据·直播带货软件开发·私域直播系统源码·私域直播平台搭建·私域直播app开发·直播带货平台搭建
云栖梦泽在3 小时前
AI安全入门:AI系统被攻击的常见场景与应对思路
大数据·人工智能·安全