QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1468|回复: 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
    + c% ^# j% O" `) A- w6 B" C+ R# z
    SparkCore:Spark原理初探(执行流程图)- r  \% I9 h& v6 P
    基本概念
    1 B) _( E4 i+ [* {' G. a9 c( g
    : n! j( p; e! b$ j1 \( c' s
    $ L8 Q  x4 H4 O# R- O5 c 2.png " |! P* a. h8 T  t/ Q+ R1 ?2 x! V
    3 c1 R+ b8 Y. C% y, j2 s, ^+ W5 \
    3.png
    8 @- h" s( h, T% A4 ]9 b. H5 ~! }% l$ W" a8 V
    名词解释
    9 R, Z; V+ h/ H; Z5 pApplication:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。
    * m4 d; d2 g5 U4 L6 BDriver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等
    ! }# g& n, X0 f6 `Cluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;% j7 v' {. V1 ^/ o8 P
    Executor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;+ g6 [- G( C4 l0 Z1 n& o
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;
    ( v9 f( m) I: S" C+ X) y# t' x' DDAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;
    & Z7 l4 n/ K* eJob:作业,按照DAG执行就是一个作业;Job==DAG
    * q3 K2 M5 w" IStage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集" U  F0 ^7 [. @6 O! k1 W8 F. W- r
    Task:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作  z$ Z/ O- L' s& M- M
    基本流程
    2 J8 n) w% ^5 p0 ^& O# k) X$ |, \" z8 W' H
    Spark运行基本流程
    5 f3 r( b& M4 R) r% T) @0 O7 `# E8 g当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,
    ' m$ w! T9 x/ KSparkContext向资源管理器注册并申请运行Executor资源;
    , ]* |- h4 ?8 v资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;
    1 }* u; {( P. X3 Q' p0 OSparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。& ]3 H" q3 l5 P0 _5 b
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。
    ! I' p+ [; c$ Y; H- ~! d* }, l. MExecutor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。8 v/ O7 d( ~; ]/ y) f) M
    流程图解
    , I  }) ]* e! B) C
    + [  c5 u) g- r! M. a6 p% Y 4.png
    : Y. Z# E5 ?, r, K, b1 H0 W1 u! C: R! p+ {
    5.png % t6 q3 n5 E: t

    8 L' i+ V1 U: p  y% U# s 6.png & i8 \# c$ x( `

    1 ?7 K; l5 l* Y# o& E$ j9 k 7.png
    ) c7 N% p" _. b* {3 z. w: E; W& `$ H9 _2 i, S* [3 v8 D
    8.png
    : o' I9 E8 n9 p$ ?5 o/ Q/ \8 n1 j* [; V" \/ Z( V5 S8 T7 t4 N9 ~4 X
    * l9 s1 H) a8 ^( V

    ) I- M5 ]) t3 d/ I8 }4 }- M9 X总结
    , V' T  Z. I( s: s  x0 d' e4 ?3 o. L
    Spark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    # U8 q: L# ]! X+ A' yRDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task% f, Q2 O. i/ m1 n6 g
    / I5 n7 v0 T) E. m5 |
    ————————————————4 O0 l+ X# I# D7 C' A& M' x
    版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    # ]- |1 ]5 g0 C$ F+ n原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268
    7 E$ d8 A* S- U
    ) X5 H/ n& [# G) o/ D; P! W
      [6 Q  _0 Q2 \6 b8 i; K! P
    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 06:39 , Processed in 0.401539 second(s), 54 queries .

    回顶部