QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1476|回复: 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
    1 H2 {: o( ~- ~$ {1 h/ m
    SparkCore:Spark原理初探(执行流程图)& X& U& Y/ R3 r0 w& d
    基本概念, h" {& o# s, }- U- M% w

    8 i! y, B! C7 U) @: v  R# Q$ w( l" |4 x5 ]: S" j5 u8 @; y, O
    2.png
    ! {: E5 V- N$ T7 v6 z! C0 D# n5 i; j. ~3 n9 u- g2 i2 D! y# v) F
    3.png , V- i% c+ F4 s* O: x* d: P

    ( C2 w: F, a9 X名词解释7 Z( n' _7 b5 R7 ^0 m
    Application:指的是用户编写的Spark应用程序/代码,包含了Driver功能代码和分布在集群中多个节点上运行的Executor代码。  o% t9 j0 m# S
    Driver:Spark中的Driver即运行上述Application的Main()函数并且创建SparkContext,SparkContext负责和ClusterManager通信,进行资源的申请、任务的分配和监控等
    7 k9 }# E- T) \* a  b2 @0 uCluster Manager:指的是在集群上获取资源的外部服务,Standalone模式下由Master负责,Yarn模式下ResourceManager负责;
    2 J9 g( L3 W5 ^8 LExecutor:是运行在工作节点Worker上的进程,负责运行任务,并为应用程序存储数据,是执行分区计算任务的进程;
    " ?' t  N4 V) b" V" a  @RDD:Resilient Distributed Dataset弹性分布式数据集,是分布式内存的一个抽象概念;
    : z5 F4 R6 e0 Q1 }# WDAG:Directed Acyclic Graph有向无环图,反映RDD之间的依赖关系和执行流程;
    8 f3 K- B5 h: p; Z3 ~Job:作业,按照DAG执行就是一个作业;Job==DAG
    5 q" X8 }0 {/ B% j, t# G0 Y  sStage:阶段,是作业的基本调度单位,同一个Stage中的Task可以并行执行,多个Task组成TaskSet任务集
    9 i0 i5 r* D5 P- B7 vTask:任务,运行在Executor上的工作单元,一个Task计算一个分区,包括pipline上的一系列操作) k+ z1 [( }" B1 q
    基本流程
    . f- z# H1 U6 ]: t% P
    % l  A4 F6 @8 a6 E- p1 [# `Spark运行基本流程
    7 S3 I9 A( v- h- }& n' ~7 I当一个Spark应用被提交时,首先需要为这个Spark Application构建基本的运行环境,即由任务控制节点(Driver)创建一个SparkContext,
    8 Q$ X) P4 s2 S; F2 MSparkContext向资源管理器注册并申请运行Executor资源;
    - d% C1 g) X- \! l8 y& k6 e9 ?, z2 F资源管理器为Executor分配资源并启动Executor进程,Executor运行情况将随着心跳发送到资源管理器上;
    % q  g7 w9 \9 G& Q: v: c7 LSparkContext根据RDD的依赖关系构建成DAG图,并提交给DAGScheduler进行解析划分成Stage,并把该Stage中的Task组成Taskset发送给TaskScheduler。$ Q! |, J  ]' ~- ]
    TaskScheduler将Task发放给Executor运行,同时SparkContext将应用程序代码发放给Executor。5 N/ k% J% z* g, N8 Z
    Executor将Task丢入到线程池中执行,把执行结果反馈给任务调度器,然后反馈给DAG调度器,运行完毕后写入数据并释放所有资源。
    ! {" o: A0 W8 v3 `! d" p  J流程图解$ L; \, w5 n5 U) X

    6 D# E' Q3 ?! t5 Z) N2 x- s 4.png 2 s1 W6 |% g$ d
    & W" a/ K* Z# r) E6 I; @+ f7 v. Y
    5.png 2 N* [/ \' B! }! }: ^' d; a) C
    / m5 f& Q) [5 w# Y  @3 \/ K
    6.png
    $ }; A- ]' d% N8 y3 }; }+ {& H/ I  E8 N" H. N- O
    7.png
    1 ^6 D6 C% X5 Y5 b* w5 r5 p
    4 A3 c: ~( L8 e# }/ T 8.png
    / ?4 M3 i3 ?6 _" z: T
    ; o* i% v* _3 ?. U: ?& F
    ; v0 H+ V( O1 K& P2 Q, ]3 R' D! X& Y  [* i. X/ K8 A3 f4 l# A# }
    总结
    8 N' b' ]; x! Q8 E/ K7 f. n# g9 d0 R
    Spark应用被提交–>SparkContext向资源管理器注册并申请资源–>启动Executor$ A# x5 k! l2 p$ k
    RDD–>构建DAG–>DAGScheduler划分Stage形成TaskSet–>TaskScheduler提交Task–>Worker上的Executor执行Task
    7 z  H+ r7 J' D- q8 Y/ V2 k. H
    3 [6 F* R$ g. J0 |6 g9 Y1 s( g————————————————. S- N/ A/ Y  c  ]5 R% M6 D
    版权声明:本文为CSDN博主「真情流露哦呦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    . P1 i" O8 n5 F4 D! v# Y* y5 }2 B, T原文链接:https://blog.csdn.net/weixin_43563705/article/details/105699268
    4 A2 r; Y0 L# A" }* i, w
    & T6 R/ S! N* X, _6 q6 m+ t& D; T/ w
    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-15 20:44 , Processed in 0.437201 second(s), 54 queries .

    回顶部