<YaRN><Official doc><RM REST API's>
Overview
- ...
YARN Architecture
- The fundamental idea of YARN is to split up the functionalities of resource management and job scheduling/monitoring into separate daemons. [基本思想是将资源管理和任务调度/监控分开。]
- The idea is to have a global ResourceManager(RM) and per-application ApplicationMaster(AM). The application is either a single job or a DAG of jobs. [思路是通过一个全局的资源管理器和一个per-app的应用管理器。]
- AM: AM is a framework specific library and is tasked with negotiating resources from the RM and working with the NM(s) to execute and monitor the tasks. [AM是由框架指定的,任务是与RM协调资源,并监控NM(s)执行tasks。]
- RM: RM has two main components: Scheduler and ApplicationsManager. [Attention: RM有两个组件,其中Scheduler完全就只是负责资源的分配;ApplicationsManager则负责接受application,选取ApplicationMaster,监控重启AM。]
- The Scheduler is responsible for allocating resources to the various running applications subject to familiar constraints of capacities, queues etc. The Scheduler is pure scheduler in the sense that it performs no monitoring or tracking of status for the application. Also, it offers no guarantees about restarting failed tasks. The Shceduler performs its scheduling function based on the resource requirements of the applications; it does so based on the abstract notion of a resource Container which incorporates elements such as memory, cpu, disk, network etc. The scheduler has a pluggable policy which is responsible for partitioning the cluster resources among the various queues, applications etc. The current schedulers such as the CapacityScheduler and the FairScheduler would be some examples of plug-ins.[Scheduler负责给运行的applications分配资源。Scheduler不会执行任何的监控或状态追踪。Scheduler基于application的资源需求进行调度,具体包括内存、cpu、硬盘、网络等。]
- The ApplicationsManager is responsible for accepting job-submissions, negotiating the first container of executing the application specific ApplicationMaster and provides the service for restarting the ApplicationMaster container on failure. [RM中的ApplicationsMaster负责接受任务提交,协调第一个应用执行容器作为ApplicationMaster,并且负责ApplicationMaster失败时的重启。]
Capacity Scheculer
- Capacity Scheduler: a pluggable scheduler for Hadoop which allows for multuple-tenants to securely share a large cluster such that their applications are allocated resources in a timely manner under constraints of allocated capacities.
- TBD...
YARN资源调度策略
什么资源?
- 一般来说,在一个分布式、多用户的系统中,我们所指的资源通常是硬件资源,包括CPU使用、内存使用、磁盘用量、IO、网络流量等。这些是比较粗粒度的,也可以考虑更高抽象层次的TPS/请求数等等。
- YARN的资源抽象比较简单,只有两种:内存和CPU。
基本概念
Container
- Container是RM分配资源的基本单位。RM负责接收用户的资源请求,并为其分配Container,而NM负责启动Container并监控资源使用。
- Container的作用不只于资源分配,还用于资源隔离。更进一步,client可以通过Container来要求只在特定节点上分配,从而保证了计算本地性。
调度器与队列
- 在YARN中,调度器是一个可插拔的组件,常见的有FIFO,CapacityScheduler,FairScheduler,可通过配置文件选择不同的调度器。
- 在RM端,根据不同的调度器,所有资源被分为一个或多个队列,每个队列包含一定量的资源。
- 因而,调度器有两个主要功能:
- 决定如何划分队列;
- 决定如何分配资源。
- 此外,调度器还有一些其他的,诸如ACL、抢占、延迟调度等特性。
事件驱动
- YARN实现了一套基于状态机的事件驱动机制:很多对象内部都有一个预先定义好的有限状态机,相应的事件会触发状态转换,状态转换的过程中会触发预先定义的钩子,钩子执行的过程中又生成新的事件,继续状态转换。
- 几个角色:
- Dispatcher —— 用于分发事件,一般是异步的。内部用一个BlockingQueue暂存所有事件。
- Event —— 事件类型。
- Handler —— 事件的消费者。每个消费者只handle特定的事件,所有Handler要在Dispatcher上注册。
pull-based
- AM通过心跳向RM申请资源,但申请的资源不能马上拿到,而是要再经过若干次心跳才能拿到。这是一种pull-based模型。
- AM通过RPC协议ApplicationMasterProtocol与RM通信。这个协议在服务器端会调用YrnScheduler的allocate方法(所有调度器都必须实现YarnScheduler接口)。allocate方法有两个作用:1. 申请、释放资源;2. 表示AM是否存活(心跳)。
常见调度器
FIFO
- 最简单的默认调度器,只有一个队列,所有用户共享。
- 先到先得,因此很容易出现一个用户占满集群所有资源的情况。
- 可以设置ACL(访问控制列表),但不能设置各个用户的优先级。
CapacityScheduler
- 在FIFO的支持上,增加多用户支持。
- 最大化集群吞吐量和利用率。
- 基本思想:每个用户可以使用特定量的资源,但集群空闲时也可以使用整个集群(因而在单用户时和FIFO差不多。这种设计主要是为了提高集群利用率。)
- 划分队列:
- 划分队列使用xml文件配置,每个队列可以使用特定百分比的资源。
- 队列可以是树状结构,子队列之和不能超过父队列。
- CapacityScheduler一个比较重要的问题就是百分比如何计算。默认的算法是DefaultResourceCalculator类的ratio方法,只考虑了内存。
- 以上,CapacityScheduler的优点就是灵活,集群的利用率高;缺点也是由其灵活性造成的,因为CapacityScheduler不支持抢占式调度,必须等上一个任务主动释放资源。
FairScheduler
- 优先保证“公平”的调度器,每个用户只有特定数量的资源可以用,即使集群很空闲。
- 使用xml文件配置,每个队列可以使用特定数量的内存和CPU。
- 队列是树状结构,只有叶子结点能提交任务。
- 优缺点:稳定,管理方便,运维成本低,相对CapacityScheduler牺牲了灵活性,整体资源利用率不高。
RM REST API's
Overview
- The RM REST API's allow the user to get information about the cluster - status on the cluster, metrics on the cluster, scheduler informtion, information about nodes in the cluster, and information about applications on the cluster.
Cluster Information API
- The cluster information resource provides overall information about the cluster.
- demo usage:
public static void getClusterInfo() throws Exception{
String url = "http://10.3.242.99:8088/ws/v1/cluster";
InputStream response = new URL(url).openStream(); Scanner scanner = new Scanner(response);
String responseBody = scanner.useDelimiter("\\A").next();
System.out.println(responseBody); }返回Json:
{
"clusterInfo": {
"id": 1497756603270,
"startedOn": 1497756603270,
"state": "STARTED",
"haState": "ACTIVE",
"rmStateStoreName": "org.apache.hadoop.yarn.server.resourcemanager.recovery.NullRMStateStore",
"resourceManagerVersion": "2.6.2",
"resourceManagerBuildVersion": "2.6.2 from 0cfd050febe4a30b1ee1551dcc527589509fb681 by jenkins source checksum d07deb9ef36deb791d0e2451db849d",
"resourceManagerVersionBuiltOn": "2015-10-22T00:49Z",
"hadoopVersion": "2.6.2",
"hadoopBuildVersion": "2.6.2 from 0cfd050febe4a30b1ee1551dcc527589509fb681 by jenkins source checksum f9ebb94bf5bf9bec892825ede28baca",
"hadoopVersionBuiltOn": "2015-10-22T00:42Z",
"haZooKeeperConnectionState": "ResourceManager HA is not enabled."
}
}【TBD:haStatus,关于RM的HA。】
Cluster Metrics API
- The cluster metrics resource provides some overall metrics about the cluster.
- demo usage:
public static void getClusterMetrics() throws Exception{
String url = "http://10.3.242.99:8088/ws/v1/cluster/metrics";
InputStream response = new URL(url).openStream(); Scanner scanner = new Scanner(response);
String responseBody = scanner.useDelimiter("\\A").next();
System.out.println(responseBody);
}return json:
{
"clusterMetrics": {
"appsSubmitted": 0,
"appsCompleted": 0,
"appsPending": 0,
"appsRunning": 0,
"appsFailed": 0,
"appsKilled": 0,
"reservedMB": 0,
"availableMB": 32768,
"allocatedMB": 0,
"reservedVirtualCores": 0,
"availableVirtualCores": 8,
"allocatedVirtualCores": 0,
"containersAllocated": 0,
"containersReserved": 0,
"containersPending": 0,
"totalMB": 32768,
"totalVirtualCores": 8,
"totalNodes": 1,
"lostNodes": 0,
"unhealthyNodes": 0,
"decommissionedNodes": 0,
"rebootedNodes": 0,
"activeNodes": 1
}
}
Cluster Scheduler API
- A scheduler resource contains information about the current scheduler configured in a cluster. It currently supports both the Fifo and Capacity Scheduler.
- You will get different information depending on which scheduler is configured so be sure to look at the type information.
- demo usage:
String clusterSchedulerUrl = "http://10.3.242.99:8088/ws/v1/cluster/scheduler";
YarnRestAPI.httpGet(clusterSchedulerUrl);return json:
{
"scheduler": {
"schedulerInfo": {
"type": "capacityScheduler",
"capacity": 100,
"usedCapacity": 0,
"maxCapacity": 100,
"queueName": "root",
"queues": {
"queue": [
{
"type": "capacitySchedulerLeafQueueInfo",
"capacity": 100,
"usedCapacity": 0,
"maxCapacity": 100,
"absoluteCapacity": 100,
"absoluteMaxCapacity": 100,
"absoluteUsedCapacity": 0,
"numApplications": 0,
"queueName": "default",
"state": "RUNNING",
"resourcesUsed": {
"memory": 0,
"vCores": 0
},
"hideReservationQueues": false,
"nodeLabels": [
"*"
],
"numActiveApplications": 0,
"numPendingApplications": 0,
"numContainers": 0,
"maxApplications": 10000,
"maxApplicationsPerUser": 10000,
"userLimit": 100,
"users": null,
"userLimitFactor": 1,
"aMResourceLimit": {
"memory": 4096,
"vCores": 1
},
"userAMResourceLimit": {
"memory": 4096,
"vCores": 1
}
}
]
}
}
}
}从返回的json可以看到,使用的capacityScheduler,其内有一个queues数组。
Cluster Applications API
- With the Applications API, you can obtain a collection of resources, each of which represents an application. When you run a GET operation on this resource, you obtain a collection of Application Objects.
- demo usage:
String clusterAppUrl = "http://10.3.242.99:8088/ws/v1/cluster/apps";
YarnRestAPI.httpGet(clusterAppUrl);
return json:
{
"apps": {
"app": [
{
"id": "application_1497756603270_0002",
"user": "root",
"name": "word count",
"queue": "default",
"state": "FINISHED",
"finalStatus": "SUCCEEDED",
"progress": 100,
"trackingUI": "History",
"trackingUrl": "http://host99:8088/proxy/application_1497756603270_0002/",
"diagnostics": "",
"clusterId": 1497756603270,
"applicationType": "MAPREDUCE",
"applicationTags": "",
"startedTime": 1497784937984,
"finishedTime": 1497784954421,
"elapsedTime": 16437,
"amContainerLogs": "http://host99:8042/node/containerlogs/container_1497756603270_0002_01_000001/root",
"amHostHttpAddress": "host99:8042",
"allocatedMB": 2048,
"allocatedVCores": 1,
"runningContainers": 1,
"memorySeconds": 239770,
"vcoreSeconds": 29,
"preemptedResourceMB": 0,
"preemptedResourceVCores": 0,
"numNonAMContainerPreempted": 0,
"numAMContainerPreempted": 0
},
{
"id": "application_1497756603270_0001",
"user": "root",
"name": "word count",
"queue": "default",
"state": "FINISHED",
"finalStatus": "SUCCEEDED",
"progress": 100,
"trackingUI": "History",
"trackingUrl": "http://host99:8088/proxy/application_1497756603270_0001/",
"diagnostics": "",
"clusterId": 1497756603270,
"applicationType": "MAPREDUCE",
"applicationTags": "",
"startedTime": 1497784895511,
"finishedTime": 1497784913807,
"elapsedTime": 18296,
"amContainerLogs": "http://host99:8042/node/containerlogs/container_1497756603270_0001_01_000001/root",
"amHostHttpAddress": "host99:8042",
"allocatedMB": -1,
"allocatedVCores": -1,
"runningContainers": -1,
"memorySeconds": 255182,
"vcoreSeconds": 34,
"preemptedResourceMB": 0,
"preemptedResourceVCores": 0,
"numNonAMContainerPreempted": 0,
"numAMContainerPreempted": 0
}
]
}
}
Query Parameters Supported
- Multiple parameters can be specified for GET operations.
- The started and finished times have a begin and end parameter to allow you to specify ranges. For example, you can request all applications that started between 1:00am and 2:00pm on 12/19/2011 with startedTimeBegin=1324256400&startedTimeEnd=1324303200.
Cluster Application Statistics API
- With the Application Statistics API, you can obtain a collection of triples, each of which contains the application type, the appplication state and the number of applications of this type and this state in RM context.
- demo usage:
String appMetricsUrl = "http://10.3.242.99:8088/ws/v1/cluster/appstatistics";
YarnRestAPI.httpGet(appMetricsUrl);return json:
{
"appStatInfo": {
"statItem": [
{
"state": "RUNNING",
"type": "*",
"count": 0
},
{
"state": "ACCEPTED",
"type": "*",
"count": 0
},
{
"state": "NEW_SAVING",
"type": "*",
"count": 0
},
{
"state": "NEW",
"type": "*",
"count": 0
},
{
"state": "KILLED",
"type": "*",
"count": 0
},
{
"state": "FINISHED",
"type": "*",
"count": 2
},
{
"state": "FAILED",
"type": "*",
"count": 0
},
{
"state": "SUBMITTED",
"type": "*",
"count": 0
}
]
}
} - 可以支持的查询参数有:states & applicationTypes
Cluster Application API
- An application resource contains information about a particular application that was submitted to a cluster.
- demo usage:
String appUrl = "http://10.3.242.99:8088/ws/v1/cluster/apps/application_1497756603270_0002";
YarnRestAPI.httpGet(appUrl);return json:
{
"app": {
"id": "application_1497756603270_0002",
"user": "root",
"name": "word count",
"queue": "default",
"state": "FINISHED",
"finalStatus": "SUCCEEDED",
"progress": 100,
"trackingUI": "History",
"trackingUrl": "http://host99:8088/proxy/application_1497756603270_0002/",
"diagnostics": "",
"clusterId": 1497756603270,
"applicationType": "MAPREDUCE",
"applicationTags": "",
"startedTime": 1497784937984,
"finishedTime": 1497784954421,
"elapsedTime": 16437,
"amContainerLogs": "http://host99:8042/node/containerlogs/container_1497756603270_0002_01_000001/root",
"amHostHttpAddress": "host99:8042",
"allocatedMB": -1,
"allocatedVCores": -1,
"runningContainers": -1,
"memorySeconds": 241431,
"vcoreSeconds": 30,
"preemptedResourceMB": 0,
"preemptedResourceVCores": 0,
"numNonAMContainerPreempted": 0,
"numAMContainerPreempted": 0
}
}
Cluster Application Attempts API
- TBD...
FYI
<YaRN><Official doc><RM REST API's>的更多相关文章
- 简单物联网:外网访问内网路由器下树莓派Flask服务器
最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...
- 利用ssh反向代理以及autossh实现从外网连接内网服务器
前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...
- 外网访问内网Docker容器
外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...
- 外网访问内网SpringBoot
外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...
- 外网访问内网Elasticsearch WEB
外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...
- 怎样从外网访问内网Rails
外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...
- 怎样从外网访问内网Memcached数据库
外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...
- 怎样从外网访问内网CouchDB数据库
外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...
- 怎样从外网访问内网DB2数据库
外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...
- 怎样从外网访问内网OpenLDAP数据库
外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...
随机推荐
- Windows 上安装 Scala
在安装 Scala 之前需要先安装 Java 环境,具体安装的详细方法就不在这里描述了. 您可以自行搜索我们网站中的内容获得其他网站的帮助来获得如何安装 Java 环境的方法. 接下来,我们可以从 S ...
- Vue.js总结 [2017.6.5]
<head> <script src="https://unpkg.com/vue/dist/vue.js"></script> </he ...
- 【模板/经典题型】min-max容斥
一定注意容斥的时候-1的系数多加了1. 然后一种很常见的min-max容斥的策略就是以每个元素的出现时间作为权值. 最后一个出现的时间即为max,也就等价于全集出现的时间.
- day32 通道 数据共享 进程池
1.管道 格式: conn1,conn2 = Pipe() 管道的两端可以进行全双工通信 如图 进程2创建了管道,它就拥有管道两端的信息,每个端点都能收发信息,它把端点信息传给进程1和进程3 ,它 ...
- spring boot(五)Spring data jpa介绍
在上篇文章springboot(二):web综合开发中简单介绍了一下spring data jpa的基础性使用,这篇文章将更加全面的介绍spring data jpa 常见用法以及注意事项 使用spr ...
- [转载]Python使用@property装饰器--getter和setter方法变成属性
原贴:为什么Python不需要getter和setter getter 和 setter在java中被广泛使用.一个好的java编程准则为:将所有属性设置为私有的,同时为属性写getter和sette ...
- Python返回函数、闭包,匿名函数
函数不仅可以作为函数参数,还可以作为函数返回结果 def pro1(c,f): def pro2(): return f(c) return pro2 #调用pro1函数时,返回的是pro2函数对象& ...
- iOS 强大第三方资源库
Github用法 git-recipesGit recipes in Chinese. 高质量的Git中文教程. lark怎样在Github上面贡献代码 my-git有关 git 的学习资料 giti ...
- Nodejs+mysql+Express: 一个简单的博客
推荐网址: https://github.com/nswbmw/N-blog/blob/backup/book/%E7%AC%AC1%E7%AB%A0%20%E4%B8%80%E4%B8%AA%E7% ...
- Weblogic禁用SSLv3和RC4算法教程
weblogic在启用https时一样会报同WebSphere那样的一SSL类漏洞,中间件修复这些漏洞原理上来说是一样的,只是在具体操作上有着较大的区别. 1. weblogic禁用SSLv3算法 编 ...