QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1469|回复: 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
    8 d$ s; x# G7 I0 }/ S; I3 q
    SparkCore:Spark原理初探(执行流程图)
    ! K1 ?: [. A/ g! ^1 x基本概念2 E) W3 B3 a; H. N
    - }- T& y8 u7 m* K- M

    ) D2 }5 g* c2 k8 ^ 2.png - Z6 {8 C6 J! b/ G
      O# g  X7 z& P+ g+ W8 b! p; q
    3.png
    , h$ ~9 W0 d4 t+ X* }3 F1 @, k, {7 i
    名词解释! Y- G) T; R% W- _6 ?1 k, M5 ?: g9 u/ o
    Application:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。. m' @4 q, w( j# V$ J# x5 h' ~
    Driver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等, v8 H7 E) K3 f+ R9 r
    Cluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;
      n+ Q7 E' `+ y2 e6 }$ YExecutor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;5 J) S; p+ v# o" o# b% c; {4 [. T' G3 v
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;4 P% ]1 d' f6 s' y& D
    DAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;- Z! E# _1 U- `# s6 S% v
    Job:作业,按照DAG执行就是一个作业;Job==DAG  e  S: b$ e6 b# @8 R. {
    Stage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集
    , d6 r  G, {( b! J8 aTask:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作
    # v" F& x# L$ q4 T基本流程
    $ M+ F1 @6 P+ [) K
    " r- @5 h9 [; JSpark运行基本流程. y! |; @, R2 `, i1 E. g
    当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,; e5 `9 }. |7 a$ K7 ^# N$ d( K1 O+ p8 K
    SparkContext向资源管理器注册并申请运行Executor资源;
    6 f. W* @$ S) M资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;
    + w, U' j5 k* O9 n# f7 _$ l$ {SparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。+ e9 P, z2 K' D7 ^: x
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。
    # N; N. S% U8 E, ZExecutor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。+ Y0 v+ q& n# L5 H& f
    流程图解) l0 l6 r: z" t# X

    % x8 @  ]( S  W/ \1 R 4.png
    , R8 Q9 D, Y& T: j: K8 K# v
    ) ?' K+ [( @: R, [3 e1 T 5.png
    0 r; C: o) _8 }0 j& `# }% U! Q" ]- Q. J8 O
    6.png
    , C% `, c& Y) B9 C6 N
    : O+ d) P6 y$ N6 }$ j 7.png . o+ k! e% l* W4 S8 {

      B; N$ {8 G. q) f 8.png
    - R8 u' X1 @5 Q3 E9 c1 \- a! h( w8 b" h; _5 b

    0 X7 l7 Z& n. A/ ^
    ! K) L3 G( r, Z; u) L总结
    + u& w* o  l, E+ V4 i9 S. k# A! u3 Z( Q
    Spark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor& ~; l1 B# V9 v# E3 r6 a! \# m
    RDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task
    ' R: m! e/ v0 t4 m/ w8 ?
    + c! w7 Z0 k! w  {1 J, R' X( G————————————————) K/ L, D( ~) h9 T
    版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ; S1 O: T( w- P: e3 O原文链接:https://blog.csdn.net/weixin_43563705/article/details/1056992685 b: r- s' X9 x! l) f

    * P0 L8 U/ x: r" U6 t6 F) T' e/ b: N6 Q9 l6 V# E6 C, F  B
    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 16:52 , Processed in 0.378955 second(s), 54 queries .

    回顶部