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");
}
data:image/s3,"s3://crabby-images/cef1e/cef1eebe102ea706f1c9c7f371c929f10db4e3fa" alt=""
StreamGraph在Client生成
分区器
data:image/s3,"s3://crabby-images/e27b0/e27b0a7034fe9728a49c4cc3585b1f545a9336bc" alt=""
data:image/s3,"s3://crabby-images/5a878/5a8788b54a43f4812d003be7066b54fbd7310a18" alt=""
JobGraph在Client生成
data:image/s3,"s3://crabby-images/3c8f7/3c8f7f615cbee5b1b4a104062d3509d2ac435a74" alt=""
data:image/s3,"s3://crabby-images/4005d/4005def3bdafb14f3a53a964b121d68a7c546b9b" alt=""
data:image/s3,"s3://crabby-images/8040b/8040b86d258ced9801f30709ec547854eeadc2bf" alt=""
data:image/s3,"s3://crabby-images/9d0e3/9d0e3ee52bebd24525475e8b5593c783adcc916d" alt=""
data:image/s3,"s3://crabby-images/9d8c4/9d8c457c33b27ea699ed0ae1a7f27ccdc09ad893" alt=""
ExecutionGraph在JobManager生成
data:image/s3,"s3://crabby-images/0b1f3/0b1f3bd07fe93489965ba1a27c7600811c397195" alt=""