对于生命周期较长的对象,YARN采用了基于服务对象管理模型对其进行管理。
该模型有一下特点:
- 每个被服务化的对象都分为4个状态
- 任何服务状态变化都可以触发另外一些动作
- 可以通过组合方式对任意服务进行组合,以便统一管理。
YARN中服务模型的类图(位于包:org.apahce.hadoop.service中)
在YARN中,resourceManager 和 nodeManager属于组合服务,他们的内部包含多个单一服务和组合服务,以实现对内部多种服务的统一管理。
所有的核心服务实际上都是一个中央异步调度器,包括ResourceManager、NodeManager、MRAppMaster等,他们维护了事先注册的事件与事件处理器,并根据接收的时间类型驱动服务的运行。
服务化和时间驱动的软件设计思想,使得YARN具有高内聚,低耦合的特点,各个模块只需要完成自己的工恩给你,模块之间采用时间联系起来,系统设计简单且维护方面。
时间: 2024-09-30 14:56:00