QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1463|回复: 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* l4 u+ g, U- ]. j: L8 }SparkCore:Spark原理初探(执行流程图)
    5 f4 L  T; T0 s; c基本概念
      B8 a. }! T9 i3 E/ \9 f6 p
    8 H2 L& @$ r* ?/ I* L" ]0 a+ `( i- C1 u
    2.png
    / @. J. x+ x' P9 q# e$ p
    5 i- R5 y  U7 P' e2 r+ [6 q: ? 3.png , L$ n$ S4 ]! w$ L  j$ h$ z

    : W) r0 J( p. V; e1 L3 a- V, z名词解释- F% j; H" Q+ |# X- Z! W
    Application:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。
    4 G$ M0 b/ u; t: KDriver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等
    ; f! I" ]5 U0 N& Q3 Z) rCluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;& x& ]/ z6 b8 O  `( F0 Q
    Executor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;
    0 W, G* w7 p! _0 R% dRDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;
    4 [- ]! b! w9 t$ T" A* s9 cDAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;* ~5 B+ K% y3 [& O1 c
    Job:作业,按照DAG执行就是一个作业;Job==DAG- ?( A. a6 i5 f7 [+ L; g3 H
    Stage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集
    9 M' g" Z' }, ~' jTask:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作/ g  o+ ]8 v4 L8 w4 Y
    基本流程8 b3 Y3 Z, F' N& d& n4 s( [2 I
    + G' ~" d( k( ^
    Spark运行基本流程' P/ O0 Z7 y. p! j3 S! j: P' P* [
    当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,: f- w4 ]/ s" g% q4 u4 r$ O
    SparkContext向资源管理器注册并申请运行Executor资源;) V% }3 N& b* w- ~- r
    资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;* w( x/ y! c! z* J: H' {
    SparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。
    3 g1 a: R) n$ TTaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。
    ; _% @+ D) M2 S' J0 S! tExecutor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。
    - Q2 \8 b' o' s! p& |1 f" i流程图解
    ; ~& @% Y2 r7 W: [; b5 e- g( E6 a3 U& z% o; ]5 V8 c/ G
    4.png + a! \8 I1 v' t% u- t! }1 B6 a

    . C4 |1 K& u, V" x/ Z 5.png - v2 K3 y0 Y" s* f9 `8 Q
    ( D; Y( _6 L% x+ m8 Z" }% H
    6.png 2 Q' N( w$ o: D* X
    5 w; w' b) ~. d
    7.png
    # U5 E; i1 T) w4 O/ c0 [$ M) o$ U* i- Q) r
    8.png
    & a: s( q) B' m5 n7 E
    3 S) X( V# a& g/ M/ t9 p2 b
    + B8 ^8 V2 r. f, {% D4 L- {, y! F, {0 U% _* y# ~
    总结& B% d2 m" U: h8 m

    8 h8 g: `3 F$ Y5 h9 N1 q! vSpark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    * f, q5 @) w  ?RDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task7 \/ w- t( K0 Y1 A  m
    0 W- \1 d9 h# V: n
    ————————————————5 A* {+ b; e2 N
    版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。$ p1 @$ R% _; p+ W/ j& B! }
    原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268; W. ^4 o( U- a/ c7 Z+ c
    1 f) I1 e( i! u: T2 Q' k% h, \+ `
    - V$ Y: q3 }: S3 X
    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-9 20:26 , Processed in 0.400300 second(s), 53 queries .

    回顶部