YARN (Yet Another Resource Negotiator)是一个资源调度平台,负责为运算程序提供服务器运算资源,相当于一个分布式的操作系统平台,而 MapReduce 等运算程序则相当于运行于操作系统之上的应用程序。
YARN 是 Hadoop2.x 版本中的一个新特性。是为了解决第一代 MapReduce 编程框架的不足,提高集群环境下的资源利用率,使其具有更好的扩展性,可用性,可靠性,向后兼容性,以 及能支持除 MapReduce 以外的更多分布式计算程序。
YARN 并不清楚用户提交的程序的运行机制,与运行的用户程序完全解耦,YARN 上可以运行各种类 型的分布式运算程序(MapReduce 只是其中的一种),比如 MapReduce、Storm 程序,Spark 程序等,只要他们各自的框架中有符合YARN 规范的资源请求机制即可,所以yarn 就成为一个通用的资源调度平台,各种运算集群都可以整合在一个物理集群上,提高资源利用率,方便数据共享。
Hadoop1.x 版本中是没有yarn的,两大核心组件为HDFS和MapReduce,HDFS负责分布式存储,MapReduce负责分布式计算,即负责编程又负责计算(编程套路+计算流程),计算流程的资源都是有MapReduce调度的,MapReduce在进行任务运算的时候是分为两个进程的jobtracker和tasktracker。
jobtracker:计算的主节点,存在单点故障。主要任务有①既要负责整个集群的资源调度,在每一个集群中还要执行多个mr任务;②还要负责每个任务启动以及进度跟踪,mapreduce任务,跟踪maptask和reducetask的进度。
tasktracker:计算的从节点,提供资源,负责计算。将整个节点的资源分为2部分mapslot和reduceslot,当只有 maptask 时,reduceslot 不能用;当只有 reducetask 时,maptask 不能用,资源极大的浪费。
缺陷总结:
①单点故障,可靠性低
②扩展性差
③资源利用率低
④资源调度只能为MapReduce服务,计算框架的资源调度使用受限
因为hadoop1.x的以上缺陷,hadoop2.x引入了yarn,yarn的最基本的想法是将资源调度和进度跟踪分开,hadoop2.x中mapreduce负责编程套路(逻辑),yarn 负责资源调度。
(1)ResourceManager:主节点,负责接收客户端的请求,提供资源调度,负责整个集群的资源调度。它主要由两个组件构成:ASM(ApplicationsManager,应用程序管理器)和Scheduler(调度器)。
应用程序管理器(ASM):负责所有任务的管理,每一个任务的启动销毁,每一个任务的进度跟踪,管理每一个应用程序的MRAppMaster(即负责每一个MRAppMaster 启动和销毁,跟踪MRAppMaster 运行状态,失败尝试重启)。
MRAppMaster(MapReduce Application Master):MapReduce 中,每一个应用程序运行的时候,先启动MRAppMaster负责管理整个应用程序,它的主要工作有:①帮助当前应用程序申请资源;②启动maptask和reducetask,③跟踪maptask任务和reducetask任务的运行状态和进度;④进行maptask和reducetask 资源的回收。
调度器(Scheduler):决定的任务的执行顺序
Yarn中的三种调度器如下:
①FIFO(First In First Out):队列调度器
内部维护的是单一的队列,哪一个任务先提交,就先进行资源分配,任务运行。
缺点:如果前面有一个大任务 后面的任务阻塞。
②FAIR:公平调度器
只有这一个job在运行,此时它获得了所有集群资源;当有多个任务时,所有任务平分资源。
缺点:没有根据任务大小进行资源分配
③CAPACITY:容器调度器
也称为计算能力调度器,可以根据任务,需要或公司每个组的真是需要,手动配置资源占比。如组1为测试组,占20% ,组2为生产占80%。每个组的内部维护了多个队列,每一个队列,都是FIFO 。
调度器总结:CAPACITY是apache版本默认使用的调度器,FAIR是CDH版本的hadoop默认使用的调度器,使用哪种调度器取决于yarn-site.xml当中的yarn.resourcemanager.scheduler.class 属性。
(2)NodeManager:从节点,真正的资源提供者,为计算任务提供资源,需要资源的时候提供,运行完成时回收资源,动态提供资源是以container为单位提供,一个container对应一个maptask或一个reducetask。
container:抽象出来的逻辑资源容器 ,nodemanager提供资源的基本单位或最小单位 内部封装了一定的资源(cpu,内存,磁盘,网络,io)。
(1)客户端提交任务(如hadoop jar...),客户端先去ResourceManager申请资源;
(2)ResourceManager返回一个资源节点用于启动当前应用程序(job)的MRAppMaster;
(3)ResourceManager到对应的节点上启动MRAppMaster;
(4)MRAppMaster向ResourceManager申请资源(如maptask或reducetask);
(5)ResourceManager向MRAppMaster返回对应的资源节点;
(6)MRAppMaster到对应的资源节点上启动一个container在其中运行maptask任务;
(7)maptask向MRAppMaster汇报自己的状态和进度;
(8)当MRAppMaster获取到有一个maptask运行完成之后,就启动一个container在其中运行reducetask任务;
(9)reducetask启动后,向MRAppMaster汇报自己的状态的进度;
(10)每一个maptask和reducetask运行完成之后,MRAppMaster就会到对应的节点上进行资源回收;
(11)整个任务运行完成,MRAppMaster向ResourceManager汇报并注销自己,并把整个运行结果返回给客户端。