当前位置: 首页 > news >正文

Flink原理与实践 · 第三章总结

Flink原理与实践 · 第三章总结

从 WordCount 出发,彻底吃透 Flink 的设计与运行原理

原文整理自《Flink原理与实践》第三章 ,作者鲁蔚征
作者:AlgoCraft
发布时间:2025-08-19


一、本章定位:从“跑起来”到“跑明白”

本章回答三个灵魂拷问:

  1. 代码 → 作业:Flink 如何把用户写的 DataStream 程序翻译成可执行的分布式任务?
  2. 作业 → 运行:JobManager、TaskManager、Slot 这些角色到底在干什么?
  3. 运行 → 资源:并行度、算子链、Slot Sharing 如何决定任务最终落在哪台机器、哪个线程?

二、一张图看懂 Flink 数据流图

1. 逻辑视图(Logical Plan)

  • 算子(Operator):Source → flatMap → keyBy → timeWindow → sum → Sink
  • 数据交换策略:Forward / KeyBy / Broadcast / Rebalance

2. 物理执行图(Physical Plan)

  • 并行切片:每个算子被拆成若干 Sub-task(又称 Instance)。
  • 并行度 = Sub-task 个数;可在代码、Client、WebUI 上设置。
  • 示例:并行度=2 ⇒ 每个算子产生 2 个 Sub-task,如 FlatMap[1/2]FlatMap[2/2]

三、Flink 分布式架构全景

组件作用备注
Client把 JAR → JobGraph → 提交给集群CLI / REST
Dispatcher为每个作业起 1 个 JobManager高可用可多实例
JobManager作业的“大脑”申请资源、生成 ExecutionGraph、故障恢复
ResourceManager管资源向 YARN / K8s / Standalone 要容器 & Slot
TaskManager作业的“肌肉”真正跑 Sub-task,向 RM 注册 Slot

一句话:Client 提交通关,JM 指挥全局,TM 干活挣钱,RM 管钱袋子


四、从代码到执行:四张图的演变

官方把“翻译”过程拆成 4 个阶段:

  1. StreamGraph
    用户代码直接映射出的 DAG,节点=算子。

  2. JobGraph
    优化阶段:把可以 链在一起 的算子合并成 Operator Chain(JobVertex),减少网络 shuffle。

  3. ExecutionGraph
    JobManager 把 JobVertex 按并行度 横向展开,形成并行实例 ExecutionVertex。

  4. 物理执行图
    ExecutionVertex 被调度到 TaskManager 的某个 Slot 内,变成真正的线程 / Task。


五、Slot 与资源隔离

  • Slot = TaskManager 资源子集
    默认 1 Slot ≈ 1 CPU core + 部分内存。

  • Slot Sharing(槽位共享)
    同一个作业的所有 Sub-task 可以塞进 一个 Slot,减少 IPC 与线程切换,提高利用率。
    示例:并行度=6,但只开 2 个 Slot,也能跑满。

  • 算子链 vs. Slot Sharing

    • 算子链:把算子“纵向”合并进同一线程。
    • Slot Sharing:把 Sub-task“横向”塞进同一 Slot。
      二者叠加,最终一个 Slot 里可能跑 多条链的多个 Sub-task

六、实战:把 WordCount 再“解剖”一次

步骤关键动作
设置并行度env.setParallelism(2)
算子链Source→FlatMap 链在一起;keyBy 不能链(发生 shuffle)
Slot SharingSource[1/2]、FlatMap[1/2]、Window[1/2] 共享 Slot1
WebUI 观察可看到 5 个 Sub-task 落在 2 个 Slot 内

七、本章实验:亲手调优 WordCount

官方实验要求:

  1. 把分词逻辑从“空格”改为 正则 \\W+,支持逗号、句号、冒号等。
  2. 本地模式跑通后,用 Flink CLI 提交到 Standalone 集群。
  3. 在 WebUI 里查看:
    • 并行度、Slot 数量
    • Sub-task 与 Slot 的映射关系
  4. 提交实验报告:代码 + 输出 + WebUI 截图。

八、小结

维度关键词
图模型StreamGraph → JobGraph → ExecutionGraph → 物理图
并行度算子子任务数,可全局或单算子设置
资源Slot、Slot Sharing、Operator Chain
角色Client / Dispatcher / JobManager / ResourceManager / TaskManager

理解本章后,再回头看任何 Flink 程序,你都能迅速画出它的 逻辑 DAG、估算 并行度、预判 资源占用——真正做到“跑起来”也“跑明白”。

http://www.dtcms.com/a/338455.html

相关文章:

  • Jenkins项目发布基础
  • 代码随想录算法训练营四十六天|图论part04
  • CSS封装大屏自定义组件(标签线)
  • 在python中等号左边的都是对象,在matlab中等号a = 3+2 a就是个变量
  • 关系型数据库与非关系型数据库
  • 用户认证技术
  • 【笔记】扩散模型(一一):Stable Diffusion XL 理论与实现
  • 力扣hot100:盛最多水的容器:双指针法高效求解最大容量问题(11)
  • [NSSCTF 2022 Spring Recruit]rrrsssaaa
  • 94、23种设计模式之工厂方法模式(3/23)
  • 用户认证技术和应用控制技术总结
  • 接口和抽象类的区别(面试回答)
  • leetcode43. 字符串相乘
  • 遗传算法求解冷链路径优化问题matlab代码
  • [ Spring 框架 ] 框架搭建和属性赋值
  • android 实现表格效果
  • 《彩色终端》诗解——ANSI 艺术解(DeepSeek)
  • shell脚本第一阶段
  • Image-to-Music API 接入文档(图片生成音乐)
  • 【新手易混】find 命令中 -perm 选项的知识点
  • ANSI终端色彩控制知识散播(I):语法封装(Python)——《彩色终端》诗评
  • JavaScript 性能优化实战技术指南
  • Coze AI大模型 Docker 部署流程详解
  • 设计模式(四)——责任链模式
  • Spring 三级缓存:破解循环依赖的底层密码
  • 【Python语法基础学习笔记】常量变量运算符函数
  • LeetCode 每日一题 2025/8/11-2025/8/17
  • 【嵌入式基础梳理#12】风压计Modbus框架示例
  • RAG:让AI成为你的知识专家
  • Maven Assembly Plugin 插件使用说明