yarn作业执行流程

yarn作业执行流程

1、客户端向ResourceManager 发送运行job的请求,申请资源
2、ResourceManager 向客户端返回一个job_id以及共享资源的路径
  /tmp/hadoop-yarn/staging/hadoop/.staging/job_id
  共享资源包含三点信息
    1)jar 包 job.jar-
    2)切片信息
    3)job.xml
3、客户端将共享资源放置在共享资源路径下
4、客户端返回消息告知ResourceManager 已经成功放置共享资源,提交应用程序
5、ResourceManager 向客户端返回运行MRAppMaster的节点(比如nodemanger01)
6、ResourceManager 到nodemanager01先启动一个Container,然后启动MRAppMaster
7、MRAppMaster对job进行初始化,将job_id改为application_id,同时生成一个job的记录簿,记录MapTask或者ReduceTask的进度以及状态
8、为了获取MapTask个数和ReduceTask个数,需要MRAppMaster去下载共享资源到本地
9、MapTask
  1)MRAppMaster向ResourceManager 申请MapTask资源
  2)ResourceManager 向MRAppMaster返回相对应的MapTask资源节点(比如nodemanger02),MapTask节点优先原则是:数据本地化优先
  3)MRAppMaster到nodemanger02先启动一个Container,再启动MapTask
  4)MapTask运行一个应用程序需要数据、应用程序、资源
缺少应用程序,所以需要MRAppMaster去下载共享资源,主要是jar包和切片信息
  5)开始运行MapTask任务
  6)MapTask在运行过程中向MRAppMaster汇报自己的进度和状态
10、当MRAppMaster获取到一个节点上的所有MapTask都完成,准备启动ReduceTask
11、ReduceTask
  1)MRAppMaster向ResourceManager 申请ReduceTask资源
  2)ResourceManager 向MRAppMaster返回相对应的ReduceTask资源节点(比如nodemanger03),ReduceTask节点优先原则是:随机
  3)MRAppMaster到nodemanger03先启动一个Container,再启动ReduceTask
  4)ReduceTask运行一个应用程序需要数据、应用程序、资源
缺少应用程序,所以需要MRAppMaster去下载共享资源,主要是jar包和job配置信息
  5)所有的MapTask完成,所有的fetch完成,开始运行ReduceTask任务
  6)ReduceTask在运行过程中通过RPC协议向MRAppMaster汇报自己的进度和状态,是为了保证在运行失败的重新启动任务
12、当MapTask和ReduceTask都完成后,MRAppMaster到相对应的节点去进行资源回收
13、应用程序完成,MRAppMaster向ResourceManager注销并关闭自己

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hadoop YARN(Yet Another Resource Negotiator)是Hadoop集群资源管理系统,负责集群资源的分配和任务的调度。以下是Hadoop YARN执行流程: 1. 提交作业:用户通过客户端YARN提交作业,包括应用程序的代码和所需的资源配置。 2. 资源请求:YARNResourceManager接收到作业提交请求后,会为作业分配一个唯一的Application ID,并将作业相关的信息记录在内部数据结构中。 3. 资源分配ResourceManager根据集群中可用的资源情况,分配合适的Container作业Container一个虚拟的计算资源单元,可以运行一个或多个任务。 4. 任务调度:一旦ResourceManager作业分配Container,它会将Container的相关信息发送给NodeManager,NodeManager负责管理和监控Container的运行。 5. 任务执行:一旦NodeManager接收到Container的信息,它会启动Container,并运行作业中的任务。任务可以是Map任务或Reduce任务,由应用程序代码定义。 6. 任务监控:NodeManager会监控任务的运行状态,并将进度和日志信息发送给ResourceManager。 7. 容错和恢复:如果任务失败或节点故障,YARN会自动重新分配和启动失败的任务。此外,它还能够根据配置策略进行容错和恢复操作。 8. 完成作业:当作业中的所有任务都成功完成时,YARN会将作业的最终状态和结果返回给客户端。 总体而言,Hadoop YARN通过ResourceManager和NodeManager的协调与管理,实现了任务的分配、调度和执行,以及容错和恢复等功能,从而实现了高效的集群资源管理和作业执行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值