QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1465|回复: 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

    . Y; |0 I0 _- T% o' e9 I: O4 TSparkCore:Spark原理初探(执行流程图)/ ?. G* v2 z0 C
    基本概念
    4 j1 `9 I8 Z' [2 L' Y2 n, }3 X3 T4 [. s. i- A) E2 B9 }1 U$ P

    9 C* R) b; M2 k- }( ?4 C1 \' w 2.png 3 |4 J$ S. i/ @8 W% f9 H7 N" N# L
    - k3 x8 y  e1 L$ I9 T+ U
    3.png / d. N* r( v- q% V, W

    7 p& k( S! h6 r( S$ }: l3 x' F4 z2 K; Q名词解释
    9 [. R8 c$ W- W+ SApplication:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。& I' c3 A- U. }; Z- e) Y
    Driver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等/ v# g* M8 e% V- d' ?7 F  t4 c
    Cluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;+ {) r. B; n+ ?; q' K
    Executor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;0 H# C$ s7 D! P
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;
    3 ?' }5 C6 f0 V% `) d! R' C2 r$ UDAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;1 ]3 G/ Z! k% x% v7 b& G) c4 q& }
    Job:作业,按照DAG执行就是一个作业;Job==DAG6 S  j) J; b- Q2 A1 w' W
    Stage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集2 [6 D/ V* P3 \$ f( C5 X, X
    Task:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作
    2 b& u& I4 ]( s8 A$ j% o基本流程
    7 O7 ?' B/ N4 z, U7 @. f: y3 r( S; o/ L2 f
    Spark运行基本流程
    : ?9 X5 b$ m+ C% A当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,
    : h% w1 U" M# NSparkContext向资源管理器注册并申请运行Executor资源;
    ! O& |1 k- J& v" [资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;! U) X3 r, @' k% t- M" c
    SparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。/ O7 V3 ?& h  M+ V% j! Q
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。
    7 y* `* S9 O/ t3 G, ~7 |" U) e  [: FExecutor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。' ]. D( y% x, O6 G# d1 n3 M0 p& w! K
    流程图解3 _& o, g& Y+ V% W& u

    ( |/ L4 Q( O: D7 W6 u+ k 4.png
    % Q/ U) Q* |" `: _) u5 k2 U" B2 ^+ r3 m/ y7 t
    5.png
    * T* ^! Z) A- S5 @( D" t8 o# [# C
    6.png ( Y& C0 O  i6 h% p5 }8 L2 ^. w5 ?' K

    % X3 ?/ c: D9 f) d" a8 u5 q 7.png ; K: Z6 d; V$ ]9 n" ?5 B6 _$ V

    3 Q+ [( z/ @/ q 8.png
    2 r- H0 P' P) N! q
    2 s8 q6 C3 w& L+ t! J
    ( X" u: ~6 z9 x% i+ l- V
    * P( v, [1 [) l/ T( d) d3 G总结
    ; v' W9 Q- d& P9 u
    ( Y% ?1 f7 Q6 ?5 m6 e, a3 qSpark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    6 ?; ^2 `5 L/ o* J9 r6 A, ~- HRDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task4 e9 n' T" f  B4 O' J0 G( N
    3 f$ g/ `* ^8 V5 T
    ————————————————
    6 v( u' W3 L: n& f版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。9 ?# D) U2 L& V4 J0 M- M& W' F
    原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268* n2 L4 z6 I8 H5 h+ {) i
    0 S% e( z+ J0 J! {

    9 ~9 X" q0 J. }/ s
    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 21:41 , Processed in 0.713134 second(s), 53 queries .

    回顶部