QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1471|回复: 0
打印 上一主题 下一主题

SparkCore:Spark原理初探(执行流程图)

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-24 18:08 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta

    " v7 A( E! W+ Y' Q4 [+ a4 W2 uSparkCore:Spark原理初探(执行流程图)
    ; d5 f7 K+ [$ I9 t' R基本概念* ]$ ]5 G0 q% f
    6 ~- e3 a. s4 m  |) W( R% a5 K
    8 M! d  C0 `7 Z- ~& j* V' I9 u
    2.png
    & N- L( N3 `8 Z
    9 }+ N# P! L1 V 3.png 3 U) d# e: h- [# {4 }, h

    & U: W0 {( a$ D2 E" ]. J名词解释
    : I" C" q0 t' L6 x/ ^8 `% gApplication:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。
    ( b% z# _4 i) U- T- K* hDriver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等: I2 S- x- e; H! x. U
    Cluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;" Z/ `0 ~( T+ u- c$ {
    Executor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;; ?3 S8 ^6 U  W% \5 o7 X' b
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;) n0 V0 ?3 I% E+ G2 t
    DAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;! h" J9 u. V) R; e) x& Z+ ?. D
    Job:作业,按照DAG执行就是一个作业;Job==DAG# s( |3 R" P* U# P' }
    Stage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集. S' J& _% }! y  m2 I" V; h2 @
    Task:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作7 P/ h9 X! P8 k2 [
    基本流程
    ) _; X8 C( J$ I: a! ?4 |3 d( ^7 s" ]& m' M* _
    Spark运行基本流程7 ^  Y2 J- x+ Y2 d: p
    当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,! R) U' C7 v) ?. H2 t' R
    SparkContext向资源管理器注册并申请运行Executor资源;
    1 [( s$ O* H$ }/ D& [2 y资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;
    2 q2 }7 w3 }) o7 @SparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。1 B4 D  B6 R* }6 T2 O
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。# B; ?% T  B8 {8 H* \# @
    Executor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。
    ; s. M) W. p4 L2 B  x4 O% L  Y流程图解7 U( i) i8 f3 M0 h

    5 u" t4 _# Y" q# t 4.png , r2 }' w: S% w. `

    6 h3 ~' Z% U. b* a 5.png
    9 ^$ I$ R* i0 j3 O1 |- s  E/ E! ?: @: R* Q
    6.png
    $ w5 {  F3 b, ^! p. M& o' s
    3 V# t# [  R) w( w! a) k8 [ 7.png $ d7 v) |+ L5 Y6 E  D6 S
    : O9 _; l" o" T; S9 w) y1 b0 @, w
    8.png
      c% W4 m4 g% g- \/ p/ F! j* `4 d6 C# M  u$ [7 E) H' S+ @
    ' U5 q' I  E8 K

    : N1 _; g  M& B, q总结
    2 M8 x' Z, R8 }8 z' {/ z1 V
    / a. d/ G1 @  ~; @# ~+ ?. S+ M' RSpark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    / K& f* v2 f4 V  lRDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task5 N7 E! O8 e2 `: _( y2 H4 t
    . Z) ^  @  |' b/ B4 _6 Y- R  L
    ————————————————
    ' d8 o/ W9 K0 |9 C4 A9 A7 \版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。1 ^8 b/ v& {% M2 x- P0 _4 m( W2 A
    原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268
    ) G4 ^; Y2 a* F/ u, {7 `  @
    - p9 d1 M) @; g  |3 v
    8 k" E6 W- F: B5 {4 I' G% y# V
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-11 06:46 , Processed in 0.373918 second(s), 54 queries .

    回顶部