YARN:执行流程

YARN(Yet Another Resource Negotiator)是Hadoop 2.x版本中引入的资源管理平台,用于管理Hadoop集群的计算资源。以下是YARN执行MapReduce作业的典型流程:

1. **作业提交(Job Submission)**:

  - 用户将MapReduce作业打包成JAR文件,并提交给YARN集群。这通常通过命令行工具或编程API完成。

2. **与ResourceManager通信(Communicate with ResourceManager)**:

  - 提交的作业首先与ResourceManager(RM)通信,ResourceManager负责整个集群的资源管理和作业调度。

3. **作业接收(Job Reception)**:

  - ResourceManager接收作业,并为作业分配一个唯一的作业ID。

4. **调度作业(Scheduling Job)**:

  - ResourceManager根据集群资源和调度策略,将作业调度到相应的节点上执行。

5. **与NodeManager通信(Communicate with NodeManager)**:

  - ResourceManager与NodeManager(NM)通信,NodeManager负责管理单个节点上的资源。

6. - **启动ApplicationMaster(Start ApplicationMaster)**:

      - ResourceManager启动一个特殊的进程ApplicationMaster(AM),它是作业的控制中心。

7. **资源请求(Resource Request)**:

  - ApplicationMaster向ResourceManager请求资源,用于启动Map任务和Reduce任务。

8. **分配容器(Allocate Containers)**:

  - ResourceManager根据调度器的决策,向ApplicationMaster分配容器,容器是YARN中的资源分配单位。

9. **启动任务(Start Tasks)**:

  - ApplicationMaster在获得容器后,会指示NodeManager启动具体的Map或Reduce任务。

10. **执行任务(Execute Tasks)**:

    - 每个任务在NodeManager上执行,Map任务生成中间结果,Reduce任务处理中间结果并生成最终输出。

11. **数据本地化(Data Localization)**:

    - 为了提高效率,YARN会尽量将任务调度到存储输入数据的节点上。

12. **任务状态汇报(Task Status Report)**:

    - 任务在执行过程中,会定期向ApplicationMaster汇报状态和进度。

13. **任务完成(Task Completion)**:

    - 任务完成后,会释放容器资源,并将状态汇报给ApplicationMaster。

14. **作业完成(Job Completion)**:

    - 所有任务完成后,ApplicationMaster向ResourceManager汇报作业完成,并关闭自己。

15. **清理(Cleanup)**:

    - ResourceManager进行清理工作,包括释放作业使用的资源和删除作业的工作目录。

16. **作业结果(Job Results)**:

    - 用户可以从指定的输出目录获取作业的结果。

YARN的执行流程是高度模块化的,ApplicationMaster作为作业的协调者,负责与ResourceManager和NodeManager交互,确保作业的顺利执行。YARN的设计使得它不仅可以运行MapReduce作业,还可以运行其他类型的分布式应用程序。

Hadoop YARN(Yet Another Resource Negotiator)是Hadoop的集群资源管理系统,负责集群资源的分配和任务的调度。以下是Hadoop YARN执行流程: 1. 提交作业:用户通过客户端向YARN提交作业,包括应用程序的代码和所需的资源配置。 2. 资源请求:YARN的ResourceManager接收到作业提交请求后,会为该作业分配一个唯一的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
发出的红包

打赏作者

大连赵哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值