QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1470|回复: 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
    + G# F6 `7 A6 f1 \* o& M
    SparkCore:Spark原理初探(执行流程图)
    % A+ }: _1 G- C0 K( K: x# }. o基本概念3 @  a; y& B9 \& B! t% G
    ) F1 v2 A: V: D: d8 ~) z
    8 B3 R0 I  i6 a. n
    2.png 9 }8 I- f$ k- W* Z) h" F
    - \/ P. W6 S9 S
    3.png ( O2 y9 T- v1 W1 f; A7 h

    0 j- B7 e# w1 b( P) D0 W! d0 Y名词解释) G! q5 X) H% D! |1 t9 D" d7 k
    Application:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。3 Q2 b) }" [  t+ d
    Driver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等
    ! u/ B% m1 g0 v3 p7 ~# }Cluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;3 z: }: e& q9 n( b3 z/ h1 }5 Q5 m
    Executor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;2 F. Q* H. @* G& Q" k; k5 L
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;: s. N. A( x8 E) M; }5 i
    DAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;  c5 i, o" C9 E8 i& `5 s( z* F
    Job:作业,按照DAG执行就是一个作业;Job==DAG
    ; O- Y% H: A" o# KStage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集
    4 @+ b1 [9 H2 RTask:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作2 D5 ^* R: ~$ ?6 m6 t/ d
    基本流程
    5 R, e5 N; u9 z- v3 c' U$ [
    , V, x+ @( e) M8 ASpark运行基本流程6 q4 u. J# v& T& F$ s( Z
    当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,- }8 n+ F% V% t+ _) J
    SparkContext向资源管理器注册并申请运行Executor资源;* K3 C) O  ~# U2 a2 A% u
    资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;
    8 O* u3 w$ r& v1 s, Z% D/ L0 z9 P; iSparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。! M! h( S1 s  d7 Y
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。' M6 J- ~9 x5 c! z
    Executor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。0 R" O0 U$ m& s4 u2 G$ H( H" x( G) l
    流程图解
    ) e8 w+ ]5 ?# {# \- k1 z5 u5 e' ^9 t4 T
    4.png $ z# a! _& k$ T2 I) D! L
    9 a% |" \5 ]& D  r) E' `0 }) D
    5.png 9 e3 ^" f# ~' v. u$ x

    & X2 p) u( c  b  f8 c) P 6.png
    : L/ G2 g2 O8 _* q" O, v  [8 }2 X! D7 Z3 D9 \0 Y
    7.png # H* j9 k: U% B5 {% o% S
    2 S6 e6 s. a4 s1 b
    8.png
    ) N4 Y7 A' m- k" I) q9 @& {3 E' i0 p9 f6 J' e0 ~

    0 C# {4 X9 ]' \; F8 H/ a$ z  M& Q4 K  M
    总结
    . f$ }) J+ k% k  U% F) I- j5 o6 s: o3 S% k& v' g" X
    Spark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    $ P6 P6 i6 [: y+ L/ C2 Y& P- SRDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task% w( x# H$ z, U1 \' t

    1 L; W. C. g/ c! Y————————————————
    ; H. K$ ?& b& q' v" m8 C, M2 I版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    - I. C: p2 F( C. T! `原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268: h9 Y. M* r8 G# g; _/ }

    7 A0 c& }; E3 r8 u3 f4 [; R
    / j  p# L$ i6 i; R
    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-10 18:15 , Processed in 1.016968 second(s), 53 queries .

    回顶部