文章授权自: http://www.6aiq.com/article/1547041236424

宽依赖与窄依赖

窄依赖(narrow dependency)和宽依赖(wide dependency, 也称 shuffle dependency).

  1. 窄依赖是指父RDD的每个分区只被子RDD的一个分区所使用,子RDD分区通常对应常数个父RDD分区(O(1),与数据规模无关), map/filter和union

  2. 相应的,宽依赖是指父RDD的每个分区都可能被多个子RDD分区所使用,子RDD分区通常对应所有的父RDD分区(O(n),与数据规模有关), join

宽依赖和窄依赖如下图所示:

相比于宽依赖,窄依赖对优化很有利 ,主要基于以下两点:

  1. 宽依赖往往对应着shuffle操作,需要在运行过程中将同一个父RDD的分区传入到不同的子RDD分区中,中间可能涉及多个节点之间的数据传输;而窄依赖的每个父RDD的分区只会传入到一个子RDD分区中,通常可以在一个节点内完成转换。

  2. 当RDD分区丢失时(某个节点故障),spark会对数据进行重算。

    1. 对于窄依赖,由于父RDD的一个分区只对应一个子RDD分区,这样只需要重算和子RDD分区对应的父RDD分区即可,所以这个重算对数据的利用率是100%的;

    2. 对于宽依赖,重算的父RDD分区对应多个子RDD分区,这样实际上父RDD 中只有一部分的数据是被用于恢复这个丢失的子RDD分区的,另一部分对应子RDD的其它未丢失分区,这就造成了多余的计算;更一般的,宽依赖中子RDD分区通常来自多个父RDD分区,极端情况下,所有的父RDD分区都要进行重新计算。

    3. 如下图所示,b1分区丢失,则需要重新计算a1,a2和a3,这就产生了冗余计算(a1,a2,a3中对应b2的数据)。

Job & Stage & Executor & Task

  • Job: A job is triggered by an action, like count() or saveAsTextFile(). 由action 触发

  • stage: 一个job会被拆分为多组Task,每组任务被称为一个Stage, Stage包含两类:

    • ShuffleMapStage in Spark

      ShuffleMapStage 是在DAG中 属于中间层的stage, 会产生map output file的write disk操作,提供给下一个stage的task使用,并且增加了网络IO,跨stage会是一种高昂的开销,很多情况下应尽量避免, 另外ShuffleMapStage可以被多个job共享!

    • ResultStage in Spark

    action操作会包含在ResultStage里,是DAG中最终的stage, 里面的task会计算最终的action结果

stage内只会存在窄依赖, stage间存在宽依赖,一定存在shuffle过程!

  • 在Spark中有两类task:

    • 一类是shuffleMapTask
    • 一类是resultTask
      第一类task的输出是shuffle所需数据,第二类task的输出是result,stage的划分也以此为依据,shuffle之前的所有变换是一个stage,shuffle之后的操作是另一个stage。比如
rdd.parallize(1 to 10).foreach(println)

这个操作没有shuffle,直接就输出了,那么只有它的task是resultTask,stage也只有一个;如果是

rdd.map(x => (x, 1)).reduceByKey(_ + _).foreach(println)

这个job因为有reduce,所以有一个shuffle过程,那么reduceByKey之前的是一个stage,执行shuffleMapTask,输出shuffle所需的数据,reduceByKey到最后是一个stage,直接就输出结果了。如果job中有多次shuffle,那么每个shuffle之前都是一个stage. 会根据RDD之间的依赖关系将DAG图划分为不同的阶段,对于窄依赖,由于partition依赖关系的确定性,partition的转换处理就可以在同一个线程里完成,窄依赖就被spark划分到同一个stage中,而对于宽依赖,只能等父RDD shuffle处理完成后,下一个stage才能开始接下来的计算。之所以称之为ShuffleMapTask是因为它需要将自己的计算结果通过shuffle到下一个stage中

因此spark划分stage的整体思路是:从后往前推,遇到宽依赖就断开,划分为一个stage;遇到窄依赖就将这个RDD加入该stage中。因此在图2中RDD C,RDD D,RDD E,RDDF被构建在一个stage中,RDD A被构建在一个单独的Stage中,而RDD B和RDD G又被构建在同一个stage中。

参考链接
[1] https://data-flair.training/blogs/spark-stage/

Spark宽依赖 窄依赖 Job Stage Executor Task 总结相关推荐

  1. Spark RDD 宽依赖窄依赖

    Spark RDD 宽依赖&窄依赖 1.窄依赖 2.宽依赖: 3.阶段的划分 4.宽依赖和窄依赖的作用: 1.窄依赖 每一个父RDD的Partition最多被子RDD的一个Partition使 ...

  2. spark中stage的划分与宽依赖/窄依赖(转载+自己理解/整理)

    [1]宽依赖和窄依赖,这是Spark计算引擎划分Stage的根源所在,遇到宽依赖,则划分为多个stage,针对每个Stage,提交一个TaskSet: 上图:一张网上的图: (个人笔记,rdd中有多个 ...

  3. Spark RDD的窄依赖和宽依赖

    目录 前言 一.窄依赖 二.宽依赖 三.使用WC演示窄依赖.宽依赖 四.窄依赖中的join 五.总结 前言 RDD的五大特性之一就是RDD之间有依赖关系,描述了RDD如何从源头计算过来的. 这样可以做 ...

  4. 宽依赖和窄依赖_spark的宽依赖窄依赖

    1RDD的依赖关系及容错 1.1RDD的依赖关系 RDD的依赖关系分为两种:窄依赖(Narrow Dependencies)与宽依赖(Wide Dependencies,源码中称为ShuffleDep ...

  5. 宽依赖和窄依赖_Spark宽依赖和窄依赖深度剖析

    宽依赖和窄依赖深度剖析.png RDD依赖关系与stage划分 Spark中RDD的高效与DAG图有着莫大的关系,在DAG调度中需要对计算过程划分stage,而划分依据就是RDD之间的依赖关系. 1. ...

  6. RDD的依赖关系、窄依赖、宽依赖、RDD的缓存、RDD缓存方式、DAG的生成、RDD容错机制之Checkpoint

    1.RDD的依赖关系 RDD和它依赖的父RDD(s)的关系有两种不同的类型,即窄依赖(narrow dependency)和宽依赖(wide dependency). 1.1.窄依赖 窄依赖指的是每一 ...

  7. Spark _08窄依赖和宽依赖stage

    专业术语: 窄依赖和宽依赖 RDD之间有一系列的依赖关系,依赖关系又分为窄依赖和宽依赖. 窄依赖 父RDD和子RDD partition之间的关系是一对一的.或者父RDD一个partition只对应一 ...

  8. 深入解读 Spark 宽依赖和窄依赖(ShuffleDependency NarrowDependency)

    目前,网上有关宽窄依赖的博客大多都使用下面这张图作为讲解: 实际上,这幅图所表达的内容并不完善.其中,窄依赖的内容表达的不够全面,而宽依赖的部分容易让人产生误解.本文,我将用新的绘图带大家搞清楚究竟什 ...

  9. Spark RDD的宽依赖和窄依赖

    系列文章目录 Spark RDD 的宽窄依赖关系 一.RDD的依赖关系? 在 Spark 中,RDD 分区的数据不支持修改,是只读的.如果想更新 RDD 分区中的数据,那么只 能对原有 RDD 进行转 ...

最新文章

  1. 分布式系统开发的一些相关理论基础——CAP、ACID、BASE
  2. MyBatis的foreach语句详解
  3. android进度条课设报告,Android开发之进度条ProgressBar的示例代码
  4. 彻底禁用chrome请停用以开发者模式运行的扩展程序弹框
  5. 感情沟通出了问题要怎么解决_感情专家咨询:感情出问题了怎么办?
  6. PHP 长连接,奏是这么简单
  7. XGBoost原理及在Python中使用XGBoost
  8. java: -source 1.5 中不支持 diamond 运算符
  9. 关于MultiActionController异步Ajax,post;
  10. 哈希函数的构造方法以及哈希表解决冲突的方式
  11. 【大数据部落】用关联规则和聚类探索药物配伍规律
  12. 兔子数列规律怎么讲_兔子繁殖问题带来的智商碾压:斐波那契数列趣谈
  13. 北航提出基于语言桥接的时空交互来进行准确指向性视频对象分割
  14. 推荐一款博客备份工具!
  15. linux 查看当前状态_Linux视频编辑的当前状态2018
  16. Linux Apache FTP-Server架设
  17. oa项目环境搭建的操作步骤详解
  18. Python交叉排序 计蒜客例题
  19. 跟我学spring security系列文章第一章 实现一个基本的登入
  20. 为什么无监督的预训练可以帮助深度学习

热门文章

  1. 2022年青龙面板部署完整版教程(多图)
  2. java之十 高级IO流
  3. 【JTAG】1687协议详解
  4. 程序员必备的十大职业生存技巧,收藏保命!
  5. 我的漫漫程序人生路(上)
  6. 服务器临时文件无法删掉,“internet临时文件”始终删不掉如何解决?临时文件无法删除的清理方法...
  7. 【合泰HT32F52352+oled温湿度显示】
  8. 世上最全NVDIA GPU参数列表: 3090,4090, A40, A30,V100, A100, A800性能参数
  9. 【操作系统】Linux体系
  10. 怒放丝路22——扬笛国画人物作品赏析