Spark源码之提交App的流程

本文详细介绍了Apache Spark中提交任务的不同方式,包括Repl提交、REST提交和本地提交等,并深入探讨了从提交jar包到最终执行task的具体过程。通过master节点进行调度,将jar包及其依赖下载到worker节点上执行。

有多种方式的提交,如Repl提交,rest的提交,本地提交等。

submit过程,在master节点提交jar包,在分配task的时候将jar包和参数里的依赖包路径等在子节点下载,最后执行task。

master在调度到LaunchDriver事件时才真正开始执行jar包的main方法,执行spark程序。

main-> LauchDriver->  rdd.compute()方法->dagSchedule.submitJob—> JobSubmmitted事件 –> finalStage –> submitStage –> submitMissingStage –> ......

 

 

    1. Rest方式

例如StandaloneRestServer

handleSubmit方法,发送DeployMessages.RequestSubmitDriver消息给master

示例代码见spark-launch和spark-core的相关代码。在deploy和launch两个目录中。

 

转载于:https://my.oschina.net/u/778683/blog/1831148

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值