我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Flink知识散点

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Flink知识散点

Flink知识散点

1、KeyBy 操作后,只有当 Key 的数量大于算子的并发实例数才能获得较好的计算性能。

A.而若Key 的数量比实例数量少,就会导致部分实例收不到数据,这些实例就得不到执行,这些实例的计算能力得不到充分发挥。
B.当Key个数多余并行实例数时,由于同一个 Key 对应的所有数据都能发送到同一个计算实例上,同一个Key中所对应的数据都能分配到同一个实例中,这样Key内计算就免去了数据传递的序列化和网络IO等开销。

2、执行环境的excute()方法

前面我们调用的所有方法,都不是在实际处理数据,而是在构通表达计算逻辑的DAG图。只有当我们将整个图构建完成并显式调用 Execute 方法后,框架才会把计算图提交到集群中,接入数据并执行实际的逻辑。

其中master负责管理整个集群中的资源和作业;而TaskExecutor 则是 Slave,负责提供具体的资源并实际执行作业。

4、Master 部分又包含了三个组件,即 Dispatcher、ResourceManager 和 JobManager。

A.Dispatcher负责接收用户提供的作业,并且负责为这个新提交的作业拉起一个新的 JobManager 组件
B.ResourceManager 负责资源的管理,在整个 Flink 集群中只有一个 ResourceManager
C.JobManager 负责管理作业的执行,在一个 Flink 集群中可能有多个作业同时执行,每个作业都有自己的 JobManager 组件。
以上三个组件都包含在 AppMaster 进程中。

5、当用户提交作业时,提交脚本会先启动一个Client进程负责作业的编译与提交。

它先将用户编写的代码编译为一个 JobGraph,在这个过程,它还会进行一些检查或优化等工作,如判断哪些 Operator 可以 Chain 到同一个 Task 中。然后,Client 将产生的 JobGraph 提交到集群中执行。此时有两种情况,一种是类似于 Standalone 这种 Session 模式,AM 会预先启动,此时 Client 直接与 Dispatcher 建立连接并提交作业即可。另一种是 Per-Job 模式,AM 不会预先启动,此时 Client 将首先向资源管理系统 (如Yarn、K8S)申请资源来启动 AM,然后再向 AM 中的 Dispatcher 提交作业。

6、当作业到 Dispatcher 后

Dispatcher 会先启动一个 JobManager 组件,然后 JobManager 会向 ResourceManager 申请资源来启动作业中具体的任务。这时根据 Session 和 Per-Job 模式的区别, TaskExecutor 可能已经启动或者尚未启动。若是前者,此时 ResourceManager 中已有记录了 TaskExecutor 注册的资源,可以直接选取空闲资源进行分配。若是后者,ResourceManager 也需要先向外部资源管理系统申请资源来启动 TaskExecutor,然后等待 TaskExecutor 注册相应资源后再继续选择空闲资源进程分配。
目前 Flink 中 TaskExecutor 的资源是通过 Slot 来描述的,一个 Slot 一般可以执行一个具体的 Task,但在一些情况下也可以执行多个相关联的 Task。ResourceManager 选择到空闲的 Slot 之后,就会通知相应的 TM “将该 Slot 分配给 JobManager XX ”,然后 TaskExecutor 进行相应的记录后,会向 JobManager 进行注册。JobManager 收到 TaskExecutor 注册上来的 Slot 后,就可以实际提交 Task 了。TaskExecutor 收到 JobManager 提交的 Task 之后,会启动一个新的线程来执行该 Task。Task 启动后就会开始进行预先指定的计算,并通过数据 Shuffle 模块互相交换数据。

1Per-job 模式下整个 Flink 集群只执行单个作业,即每个作业会独享 Dispatcher 和 ResourceManager 组件。此外,Per-job 模式下 AppMaster 和 TaskExecutor 都是按需申请的。因此,Per-job 模式更适合运行执行时间较长的大作业,这些作业对稳定性要求较高,并且对申请资源的时间不敏感。【一般配合yarn、mesose、k8s等外部资源管理器】
7.2与之对应,在 Session 模式下,Flink 预先启动 AppMaster 以及一组 TaskExecutor,然后在整个集群的生命周期中会执行多个作业。可以看出,Session 模式更适合规模小,执行时间短的作业。【一般在standalone模式下使用】

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Flink知识散点

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Flink知识散点

1、KeyBy 操作后,只有当 Key 的数量大于算子的并发实例数才能获得较好的计算性能。A.而若Key 的数量比实例数量少,就会导致部分实例收不到数据,这些实例就得不到执行,这些实例的计算能力得不到充分发挥。B.当Key个数多余并行实例数时,由于同一个 Ke
Flink知识散点
2016-07-06

JavaScript 知识点

立即执行函数 代码(function () {// ...})(); 创建函数的同时立即执行,没有绑定任何事件,也无需等待任何异步操作function () {} 是一个匿名函数,包围它的一对括号将其转换为一个表达式,紧跟其后的一对括号调用
2023-08-30

MySQL知识点

比较符有:=、>、=、<=、!=、 逻辑符号有:and、or 、not 范围运算符:between … and ..、in、not in 模糊运算:like ‘%_’:%匹配任意字符,_匹配单个字符; 空运算:null、is null、not … is nul
MySQL知识点
2019-04-20
2024-04-02

Redis知识点(一)

Redis 是 C 语言开发的一个开源的(遵从 BSD 协议)高性能键值对(key-value)的内存数据库,可以用作数据库、缓存、消息中间件等是一种 NoSQL(not-only sql,泛指非关系型数据库)的数据库。Redis 作为一个内存数据库:性能优秀
Redis知识点(一)
2015-03-28

Redis知识点(二)

首先 Redis 内部使用一个 redisObject 对象来表示所有的 key 和 value。redisObject 最主要的信息如上图所示:type 表示一个 value 对象具体是何种数据类型,encoding 是不同数据类型在 Redis 内部的存储
Redis知识点(二)
2019-08-16

Java IO知识点

1:file:文件的创建和删除;File file=new File("D:word.txt");绝对路径File file=new File("word.txt");相对路径if(!file.exists()) { file.createNewFile();
Java IO知识点
2015-11-04

python str.format知识点

在Python3.6.5版本测试通过语法 str.format(*args, **kwargs)它通过{}和:来代替%。"映射”示例:1.通过位置In [1]: '{0},{1}'.format('kzc',18)Out[1]: 'kzc,
2023-01-30

MySQL知识点总结

MySQL知识点总结一、      MySQL常用命令启动MySQL服务:service mysqld start 或 systemctl start mysqld.service停止MySQL服务:service mysqld stop 或 systemct
MySQL知识点总结
2019-07-01

MongoDB知识点总结

一:MongoDB 概述    一、NoSQL 简介       1. 概念:NoSQL(Not Only SQL的缩写),指的是非关系型数据库,是对不同于传统的关系型数据库的数据库管理系统的统称。用于超大规模数据的存储,数据存储不需要固定的模式,无需多余操作
MongoDB知识点总结
2019-04-03

必背知识点-3

问题1、DHCP 的报文的发送方式是什么? 答案:广播   问题2、什么是广播域? 答案:广播的范围。即一个网段,就是一个广播域。     问题3、DHCP的报文是否可以发送到其他的广播域? 答案:不可以。     问题4、DHCP客户端与
2023-01-31

MongoDB知识点提要

MongoDB概述MongoDB是一款NoSQL类型的文档型数据库。NoSQLNoSQL是一种非关系型DMS,不需要固定的架构,可以避免joins链接,并且易于扩展。NoSQL数据库用于具有庞大数据存储需求的分布式数据存储。NoSQL用于大数据和实时Web应用
MongoDB知识点提要
2018-11-17

【Java知识点大全】

文章目录 前言 Java基础知识点 计算机基础问题 深拷贝和浅拷贝 伪共享的概念以及如何避免 网络四元组 TCP协议为什么要设计三次握手?
2023-08-20

编程热搜

目录