QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1462|回复: 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/ U5 c/ R4 n& S  W1 ?+ p! c7 d5 Z! B
    SparkCore:Spark原理初探(执行流程图)  ?9 C3 X4 s' g. l& ~
    基本概念
    0 j+ `: M0 V6 t. Q+ d  N
    7 U# Y4 L6 K8 x/ b7 _: m" l
    3 `9 k$ y  h+ w 2.png
    % `9 a5 q' B. R
    # j( C# f! ]/ ]: H3 o8 m, a 3.png
      `7 Z" ^3 h; }) k7 l- o/ y9 [, P! q- k) y# z! w
    名词解释
    & t0 l0 _( F5 g- ^  B9 ]3 q2 E% UApplication:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。/ Z$ W- ]& I9 y8 P
    Driver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等
    / X: A5 Y0 y( w$ U  QCluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;
    # m! X, d" @* v/ aExecutor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;2 s2 l+ c( K/ ^) B  \; p
    RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;) K2 w3 ]* t: d
    DAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;) z: e( ?6 o# w2 _5 @4 M
    Job:作业,按照DAG执行就是一个作业;Job==DAG
    * Y9 G* \, m" iStage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集
    ( ^( {9 G  S3 I/ f. V$ XTask:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作4 d3 @# ^8 A$ y5 s6 Q0 Z- Z
    基本流程5 C2 X/ @% O! g' ^: I

    , ^$ ^+ _1 c( p- M: M0 j( M1 Q. v4 sSpark运行基本流程
    $ w4 G6 c  v4 w/ D: D# Q- }1 X当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,
    ' ?9 O! T6 `1 m. v% uSparkContext向资源管理器注册并申请运行Executor资源;( F+ C2 F# q7 @) \
    资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;# [1 I4 @. ~9 _% ]9 |
    SparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。
    * M% j. f7 c2 t! d) R/ VTaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。
    7 i9 E9 q/ V1 y7 E  g0 W2 |Executor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。
    4 J! ?% @0 V8 B2 \6 f5 ?! U流程图解
    . `1 A8 L# O8 g0 `1 D! }* P  E1 q" J2 b* ^( I
    4.png ! H' f0 U; L! |* x
      s3 W) N; V) m
    5.png
    8 f5 f$ r) W1 k! Z* P* |" k
    + m( H. `2 |' h5 P& G2 U8 e0 M6 j1 h 6.png
    6 ~% \5 Z  p  N" L
    ; {. v: i4 j: v0 M. b1 W6 d1 ?3 H( _ 7.png
    * M5 P$ N# [# ]! R
      w* y, X4 y1 m( q) ~8 o4 O5 C 8.png * X2 P/ p6 d, \
    0 p; H7 s6 y' [% U7 w
    7 i1 a9 w! `% l
    + D3 I- y. U# M% E
    总结5 P# f' B/ j( y9 A
      j9 j) X6 C6 u$ L+ t' H7 ^7 l
    Spark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor
    # }% F; r/ F8 A7 X% {5 e0 T! PRDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task
    & \7 q: [1 H! n: P3 ?8 M& a- ]2 [9 J; K6 w5 x2 U& q
    ————————————————
    5 d  G. J# h5 Q/ O% Q版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。8 ^* s: b6 \, ^9 ~- v8 l: Q
    原文链接:https://blog.csdn.net/weixin_43563705/article/details/1056992685 G, ^1 c' u+ D: F, n: h  y! r

    ' h2 ^' i; Y* q, F  S- n' d+ [0 G6 e8 T
    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 18:49 , Processed in 0.389558 second(s), 53 queries .

    回顶部