~~ Licensed under the Apache License, Version 2.0 (the "License"); ~~ you may not use this file except in compliance with the License. ~~ You may obtain a copy of the License at ~~ ~~ http://www.apache.org/licenses/LICENSE-2.0 ~~ ~~ Unless required by applicable law or agreed to in writing, software ~~ distributed under the License is distributed on an "AS IS" BASIS, ~~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ~~ See the License for the specific language governing permissions and ~~ limitations under the License. See accompanying LICENSE file. --- ResourceManager REST API's. --- --- ${maven.build.timestamp} ResourceManager REST API's. \[ {{{./index.html}Go Back}} \] %{toc|section=1|fromDepth=0|toDepth=2} * Overview The ResourceManager REST API's allow the user to get information about the cluster - status on the cluster, metrics on the cluster, scheduler information, 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. ** URI Both of the following URI's give you the cluster information. ------ * http:///ws/v1/cluster * http:///ws/v1/cluster/info ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ None ------ ** Elements of the object *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | id | long | The cluster id | *---------------+--------------+-------------------------------+ | startedOn | long | The time the cluster started (in ms since epoch)| *---------------+--------------+-------------------------------+ | state | string | The ResourceManager state - valid values are: NOTINITED, INITED, STARTED, STOPPED| *---------------+--------------+-------------------------------+ | resourceManagerVersion | string | Version of the ResourceManager | *---------------+--------------+-------------------------------+ | resourceManagerBuildVersion | string | ResourceManager build string with build version, user, and checksum | *---------------+--------------+-------------------------------+ | resourceManagerVersionBuiltOn | string | Timestamp when ResourceManager was built (in ms since epoch)| *---------------+--------------+-------------------------------+ | hadoopVersion | string | Version of hadoop common | *---------------+--------------+-------------------------------+ | hadoopBuildVersion | string | Hadoop common build string with build version, user, and checksum | *---------------+--------------+-------------------------------+ | hadoopVersionBuiltOn | string | Timestamp when hadoop common was built(in ms since epoch)| *---------------+--------------+-------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/info ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "clusterInfo": { "id":1324053971963, "startedOn":1324053971963, "state":"STARTED", "resourceManagerVersion":"0.23.1-SNAPSHOT", "resourceManagerBuildVersion":"0.23.1-SNAPSHOT from 1214049 by user1 source checksum 050cd664439d931c8743a6428fd6a693", "resourceManagerVersionBuiltOn":"Tue Dec 13 22:12:48 CST 2011", "hadoopVersion":"0.23.1-SNAPSHOT", "hadoopBuildVersion":"0.23.1-SNAPSHOT from 1214049 by user1 source checksum 11458df3bb77342dca5f917198fad328", "hadoopVersionBuiltOn":"Tue Dec 13 22:12:26 CST 2011" } } +---+ <> HTTP Request: ----- Accept: application/xml GET http:///ws/v1/cluster/info ----- Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 712 Server: Jetty(6.1.26) +---+ Response Body: +---+ 1324053971963 1324053971963 STARTED 0.23.1-SNAPSHOT 0.23.1-SNAPSHOT from 1214049 by user1 source checksum 050cd664439d931c8743a6428fd6a693 Tue Dec 13 22:12:48 CST 2011 0.23.1-SNAPSHOT 0.23.1-SNAPSHOT from 1214049 by user1 source checksum 11458df3bb77342dca5f917198fad328 Tue Dec 13 22:12:48 CST 2011 +---+ * Cluster Metrics API The cluster metrics resource provides some overall metrics about the cluster. More detailed metrics should be retrieved from the jmx interface. ** URI ------ * http:///ws/v1/cluster/metrics ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ None ------ ** Elements of the object *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | appsSubmitted | int | The number of applications submitted | *---------------+--------------+-------------------------------+ | reservedMB | long | The amount of memory reserved in MB | *---------------+--------------+-------------------------------+ | availableMB | long | The amount of memory available in MB | *---------------+--------------+-------------------------------+ | allocatedMB | long | The amount of memory allocated in MB | *---------------+--------------+-------------------------------+ | totalMB | long | The amount of total memory in MB | *---------------+--------------+-------------------------------+ | containersAllocated | int | The number of containers allocated | *---------------+--------------+-------------------------------+ | totalNodes | int | The total number of nodes | *---------------+--------------+-------------------------------+ | activeNodes | int | The number of active nodes | *---------------+--------------+-------------------------------+ | lostNodes | int | The number of lost nodes | *---------------+--------------+-------------------------------+ | unhealthyNodes | int | The number of unhealthy nodes | *---------------+--------------+-------------------------------+ | decommissionedNodes | int | The number of nodes decommissioned | *---------------+--------------+-------------------------------+ | rebootedNodes | int | The number of nodes rebooted | *---------------+--------------+-------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/metrics ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "clusterMetrics": { "appsSubmitted":4, "reservedMB":0, "availableMB":8192, "allocatedMB":0, "totalMB":8192, "containersAllocated":0, "totalNodes":1, "activeNodes":1, "lostNodes":0, "unhealthyNodes":0, "decommissionedNodes":0, "rebootedNodes":0 } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/metrics Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 432 Server: Jetty(6.1.26) +---+ Response Body: +---+ 4 0 8192 0 0 8192 1 1 0 0 0 0 +---+ * 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. ** URI ------ * http:///ws/v1/cluster/scheduler ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ None ------ ** Capacity Scheduler API The capacity scheduler supports hierarchical queues. This one request will print information about all the queues and any subqueues they have. Queues that can actually have jobs submitted to them are referred to as leaf queues. These queues have additional data associated with them. ** Elements of the object *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | type | string | Scheduler type - capacityScheduler| *---------------+--------------+-------------------------------+ | capacity | float | Configured queue capacity in percentage relative to its parent queue | *---------------+--------------+-------------------------------+ | usedCapacity | float | Used queue capacity in percentage | *---------------+--------------+-------------------------------+ | maxCapacity | float | Configured maximum queue capacity in percentage relative to its parent queue| *---------------+--------------+-------------------------------+ | queueName | string | Name of the queue | *---------------+--------------+-------------------------------+ | queues | array of queues(JSON)/zero or more queue objects(XML) | A collection of queue resources| *---------------+--------------+-------------------------------+ ** Elements of the queues/subQueues object for a Parent queue *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | capacity | float | Configured queue capacity in percentage relative to its parent queue | *---------------+--------------+-------------------------------+ | usedCapacity | float | Used queue capacity in percentage | *---------------+--------------+-------------------------------+ | maxCapacity | float | Configured maximum queue capacity in percentage relative to its parent queue | *---------------+--------------+-------------------------------+ | absoluteCapacity | float | Absolute capacity percentage this queue can use of entire cluster | *---------------+--------------+-------------------------------+ | absoluteMaxCapacity | float | Absolute maximum capacity percentage this queue can use of the entire cluster | *---------------+--------------+-------------------------------+ | absoluteUsedCapacity | float | Absolute used capacity percentage this queue is using of the entire cluster | *---------------+--------------+-------------------------------+ | numApplications | int | The number of applications currently in the queue | *---------------+--------------+-------------------------------+ | usedResources | string | A string describing the current resources used by the queue | *---------------+--------------+-------------------------------+ | queueName | string | The name of the queue | *---------------+--------------+-------------------------------+ | state | string of QueueState | The state of the queue | *---------------+--------------+-------------------------------+ | subQueues | array of queues(JSON)/zero or more queue objects(XML) | A collection of sub-queue information| *---------------+--------------+-------------------------------+ ** Elements of the queues/subQueues object for a Leaf queue - contains all elements in parent plus the following: *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | type | String | type of the queue - capacitySchedulerLeafQueueInfo | *---------------+--------------+-------------------------------+ | numActiveApplications | int | The number of active applications in this queue | *---------------+--------------+-------------------------------+ | numPendingApplications | int | The number of pending applications in this queue | *---------------+--------------+-------------------------------+ | numContainers | int | The number of containers being used | *---------------+--------------+-------------------------------+ | maxApplications | int | The maximum number of applications this queue can have | *---------------+--------------+-------------------------------+ | maxApplicationsPerUser | int | The maximum number of applications per user this queue can have | *---------------+--------------+-------------------------------+ | maxActiveApplications | int | The maximum number of active applications this queue can have | *---------------+--------------+-------------------------------+ | maxActiveApplicationsPerUser | int | The maximum number of active applications per user this queue can have| *---------------+--------------+-------------------------------+ | userLimit | int | The minimum user limit percent set in the configuration | *---------------+--------------+-------------------------------+ | userLimitFactor | float | The user limit factor set in the configuration | *---------------+--------------+-------------------------------+ *** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/scheduler ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "scheduler" : { "schedulerInfo" : { "queueName" : "root", "maxCapacity" : 100, "type" : "capacityScheduler", "queues" : [ { "numPendingApplications" : 0, "queueName" : "default", "userLimitFactor" : 1, "maxApplications" : 7000, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 90, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 90, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 70, "maxActiveApplicationsPerUser" : 1, "capacity" : 70, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 7000 }, { "queueName" : "test", "absoluteUsedCapacity" : 0, "absoluteCapacity" : 20, "usedCapacity" : 0, "capacity" : 20, "subQueues" : [ { "numPendingApplications" : 0, "queueName" : "a1", "userLimitFactor" : 1, "maxApplications" : 1200, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 80, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 16.000002, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 12, "maxActiveApplicationsPerUser" : 1, "capacity" : 60.000004, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 1200 }, { "numPendingApplications" : 0, "queueName" : "a2", "userLimitFactor" : 1, "maxApplications" : 800, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 100, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 100, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 8.000001, "maxActiveApplicationsPerUser" : 1, "capacity" : 40, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 800 } ], "state" : "RUNNING", "maxCapacity" : 80, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 80 }, { "queueName" : "test2", "absoluteUsedCapacity" : 0, "absoluteCapacity" : 10, "usedCapacity" : 0, "capacity" : 10, "subQueues" : [ { "numPendingApplications" : 0, "queueName" : "a5", "userLimitFactor" : 1, "maxApplications" : 500, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 100, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 100, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 5, "maxActiveApplicationsPerUser" : 1, "capacity" : 50, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 500 }, { "numPendingApplications" : 0, "queueName" : "a3", "userLimitFactor" : 1, "maxApplications" : 400, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 100, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 100, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 4.0000005, "maxActiveApplicationsPerUser" : 1, "capacity" : 40, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 400 }, { "numPendingApplications" : 0, "queueName" : "a4", "userLimitFactor" : 1, "maxApplications" : 100, "usedCapacity" : 0, "numContainers" : 0, "state" : "RUNNING", "maxCapacity" : 100, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 100, "maxActiveApplications" : 1, "numActiveApplications" : 0, "absoluteUsedCapacity" : 0, "userLimit" : 100, "absoluteCapacity" : 1.0000001, "maxActiveApplicationsPerUser" : 1, "capacity" : 10, "type" : "capacitySchedulerLeafQueueInfo", "maxApplicationsPerUser" : 100 } ], "state" : "RUNNING", "maxCapacity" : 15.000001, "numApplications" : 0, "usedResources" : "memory: 0", "absoluteMaxCapacity" : 15.000001 } ], "usedCapacity" : 0, "capacity" : 100 } } } +---+ <> HTTP Request: ----- Accept: application/xml GET http:///ws/v1/cluster/scheduler ----- Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 5778 Server: Jetty(6.1.26) +---+ Response Body: +---+ 100.0 0.0 100.0 root 70.0 0.0 90.0 70.0 90.0 0.0 0 memory: 0 default RUNNING 0 0 0 7000 7000 1 1 100 1.0 20.0 0.0 80.0 20.0 80.0 0.0 0 memory: 0 test RUNNING 60.000004 0.0 80.0 12.0 16.000002 0.0 0 memory: 0 a1 RUNNING 0 0 0 1200 1200 1 1 100 1.0 40.0 0.0 100.0 8.000001 100.0 0.0 0 memory: 0 a2 RUNNING 0 0 0 800 800 1 1 100 1.0 10.0 0.0 15.000001 10.0 15.000001 0.0 0 memory: 0 test2 RUNNING 50.0 0.0 100.0 5.0 100.0 0.0 0 memory: 0 A4 RUNNING 0 0 0 500 500 1 1 100 1.0 40.0 0.0 100.0 4.0000005 100.0 0.0 0 memory: 0 a3 RUNNING 0 0 0 400 400 1 1 100 1.0 10.0 0.0 100.0 1.0000001 100.0 0.0 0 memory: 0 a4 RUNNING 0 0 0 100 100 1 1 100 1.0 +---+ ** Fifo Scheduler API ** Elements of the object *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | type | string | Scheduler type - fifoScheduler | *---------------+--------------+-------------------------------+ | capacity | float | Queue capacity in percentage | *---------------+--------------+-------------------------------+ | usedCapacity | float | Used queue capacity in percentage | *---------------+--------------+-------------------------------+ | qstate | string | State of the queue - valid values are: STOPPED, RUNNING| *---------------+--------------+-------------------------------+ | minQueueMemoryCapacity | int | Minimum queue memory capacity | *---------------+--------------+-------------------------------+ | maxQueueMemoryCapacity | int | Maximum queue memory capacity | *---------------+--------------+-------------------------------+ | numNodes | int | The total number of nodes | *---------------+--------------+-------------------------------+ | usedNodeCapacity | int | The used node capacity | *---------------+--------------+-------------------------------+ | availNodeCapacity | int | The available node capacity | *---------------+--------------+-------------------------------+ | totalNodeCapacity | int | The total node capacity | *---------------+--------------+-------------------------------+ | numContainers | int | The number of containers | *---------------+--------------+-------------------------------+ *** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/scheduler ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "scheduler": { "schedulerInfo": { "type":"fifoScheduler", "capacity":1, "usedCapacity":"NaN", "qstate":"RUNNING", "minQueueMemoryCapacity":1024, "maxQueueMemoryCapacity":10240, "numNodes":0, "usedNodeCapacity":0, "availNodeCapacity":0, "totalNodeCapacity":0, "numContainers":0 } } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/scheduler Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 432 Server: Jetty(6.1.26) +---+ Response Body: +---+ 1.0 NaN RUNNING 1024 10240 0 0 0 0 0 +---+ * 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. ** URI ------ * http:///ws/v1/cluster/apps ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported Multiple paramters can be specified. The started and finished times have a begin and end parameter to allow you to specify ranges. For example, one could request all applications that started between 1:00am and 2:00pm on 12/19/2011 with startedTimeBegin=1324256400&startedTimeEnd=1324303200. If the Begin parameter is not specfied, it defaults to 0, and if the End parameter is not specified, it defaults to infinity. ------ * state - state of the application * user - user name * queue - queue name * limit - total number of app objects to be returned * startedTimeBegin - applications with start time beginning with this time, specified in ms since epoch * startedTimeEnd - applications with start time ending with this time, specified in ms since epoch * finishedTimeBegin - applications with finish time beginning with this time, specified in ms since epoch * finishedTimeEnd - applications with finish time ending with this time, specified in ms since epoch ------ ** Elements of the (Applications) object When you make a request for the list of applications, the information will be returned as a collection of app objects. See also {{Application API}} for syntax of the app object. *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | app | array of app objects(JSON)/zero or more application objects(XML) | The collection of application objects | *---------------+--------------+--------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/apps ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "apps": { "app": [ { "finishedTime" : 1326815598530, "amContainerLogs" : "http://host.domain.com:8042/node/containerlogs/container_1326815542473_0001_01_000001", "trackingUI" : "History", "state" : "FINISHED", "user" : "user1", "id" : "application_1326815542473_0001", "clusterId" : 1326815542473, "finalStatus" : "SUCCEEDED", "amHostHttpAddress" : "host.domain.com:8042", "progress" : 100, "name" : "word count", "startedTime" : 1326815573334, "elapsedTime" : 25196, "diagnostics" : "", "trackingUrl" : "http://host.domain.com:8088/proxy/application_1326815542473_0001/jobhistory/job/job_1326815542473_1_1", "queue" : "default" }, { "finishedTime" : 1326815789546, "amContainerLogs" : "http://host.domain.com:8042/node/containerlogs/container_1326815542473_0002_01_000001", "trackingUI" : "History", "state" : "FINISHED", "user" : "user1", "id" : "application_1326815542473_0002", "clusterId" : 1326815542473, "finalStatus" : "SUCCEEDED", "amHostHttpAddress" : "host.domain.com:8042", "progress" : 100, "name" : "Sleep job", "startedTime" : 1326815641380, "elapsedTime" : 148166, "diagnostics" : "", "trackingUrl" : "http://host.domain.com:8088/proxy/application_1326815542473_0002/jobhistory/job/job_1326815542473_2_2", "queue" : "default" } ] } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/apps Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 2459 Server: Jetty(6.1.26) +---+ Response Body: +---+ application_1326815542473_0001 user1 word count default FINISHED SUCCEEDED 100.0 History http://host.domain.com:8088/proxy/application_1326815542473_0001/jobhistory/job /job_1326815542473_1_1 1326815542473 1326815573334 1326815598530 25196 http://host.domain.com:8042/node/containerlogs/container_1326815542473_0001 _01_000001 host.domain.com:8042 application_1326815542473_0002 user1 Sleep job default FINISHED SUCCEEDED 100.0 History http://host.domain.com:8088/proxy/application_1326815542473_0002/jobhistory/job/job_1326815542473_2_2 1326815542473 1326815641380 1326815789546 148166 http://host.domain.com:8042/node/containerlogs/container_1326815542473_0002_01_000001 host.domain.com:8042 +---+ * Cluster {Application API} An application resource contains information about a particular application that was submitted to a cluster. ** URI Use the following URI to obtain an app object, from a application identified by the {appid} value. ------ * http:///ws/v1/cluster/apps/{appid} ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ None ------ ** Elements of the (Application) object Note that depending on security settings a user might not be able to see all the fields. *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | id | string | The application id | *---------------+--------------+--------------------------------+ | user | string | The user who started the application | *---------------+--------------+--------------------------------+ | name | string | The application name | *---------------+--------------+--------------------------------+ | queue | string | The queue the application was submitted to| *---------------+--------------+--------------------------------+ | state | string | The application state according to the ResourceManager - valid values are: NEW, SUBMITTED, ACCEPTED, RUNNING, FINISHED, FAILED, KILLED| *---------------+--------------+--------------------------------+ | finalStatus | string | The final status of the application if finished - reported by the application itself - valid values are: UNDEFINED, SUCCEEDED, FAILED, KILLED| *---------------+--------------+--------------------------------+ | progress | float | The progress of the application as a percent | *---------------+--------------+--------------------------------+ | trackingUI | string | Where the tracking url is currently pointing - History (for history server) or ApplicationMaster | *---------------+--------------+--------------------------------+ | trackingUrl | string | The web URL that can be used to track the application | *---------------+--------------+--------------------------------+ | diagnostics | string | Detailed diagnostics information | *---------------+--------------+--------------------------------+ | clusterId | long | The cluster id | *---------------+--------------+--------------------------------+ | startedTime | long | The time in which application started (in ms since epoch)| *---------------+--------------+--------------------------------+ | finishedTime | long | The time in which the application finished (in ms since epoch) | *---------------+--------------+--------------------------------+ | elapsedTime | long | The elapsed time since the application started (in ms)| *---------------+--------------+--------------------------------+ | amContainerLogs | string | The URL of the application master container logs| *---------------+--------------+--------------------------------+ | amHostHttpAddress | string | The nodes http address of the application master | *---------------+--------------+--------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/apps/application_1326821518301_0005 ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "app" : { "finishedTime" : 1326824991300, "amContainerLogs" : "http://host.domain.com:8042/node/containerlogs/container_1326821518301_0005_01_000001", "trackingUI" : "History", "state" : "FINISHED", "user" : "user1", "id" : "application_1326821518301_0005", "clusterId" : 1326821518301, "finalStatus" : "SUCCEEDED", "amHostHttpAddress" : "host.domain.com:8042", "progress" : 100, "name" : "Sleep job", "startedTime" : 1326824544552, "elapsedTime" : 446748, "diagnostics" : "", "trackingUrl" : "http://host.domain.com:8088/proxy/application_1326821518301_0005/jobhistory/job/job_1326821518301_5_5", "queue" : "a1" } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/apps/application_1326821518301_0005 Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 847 Server: Jetty(6.1.26) +---+ Response Body: +---+ application_1326821518301_0005 user1 Sleep job a1 FINISHED SUCCEEDED 100.0 History http://host.domain.com:8088/proxy/application_1326821518301_0005/jobhistory/job/job_1326821518301_5_5 1326821518301 1326824544552 1326824991300 446748 http://host.domain.com:8042/node/containerlogs/container_1326821518301_0005_01_000001 host.domain.com:8042 +---+ * Cluster Nodes API With the Nodes API, you can obtain a collection of resources, each of which represents a node. When you run a GET operation on this resource, you obtain a collection of Node Objects. ** URI ------ * http:///ws/v1/cluster/nodes ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ * state - the state of the node * healthy - true or false ------ ** Elements of the object When you make a request for the list of nodes, the information will be returned as a collection of node objects. See also {{Node API}} for syntax of the node object. *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | node | array of node objects(JSON)/zero or more node objects(XML) | A collection of node objects | *---------------+--------------+-------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/nodes ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "nodes": { "node": [ { "rack":"\/default-rack", "state":"NEW", "id":"h2:1235", "nodeHostName":"h2", "nodeHTTPAddress":"h2:2", "healthStatus":"Healthy", "lastHealthUpdate":1324056895432, "healthReport":"Healthy", "numContainers":0, "usedMemoryMB":0 "availMemoryMB":8192 }, { "rack":"\/default-rack", "state":"NEW", "id":"h1:1234", "nodeHostName":"h1", "nodeHTTPAddress":"h1:2", "healthStatus":"Healthy", "lastHealthUpdate":1324056895092, "healthReport":"Healthy", "numContainers":0, "usedMemoryMB":0, "availMemoryMB":8192 } ] } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/nodes Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 1104 Server: Jetty(6.1.26) +---+ Response Body: +---+ /default-rack RUNNING h2:1234 h2 h2:2 Healthy 1324333268447 Healthy 0 0 5120 /default-rack RUNNING h1:1234 h1 h1:2 Healthy 1324333268447 Healthy 0 0 5120 +---+ * Cluster {Node API} A node resource contains information about a node in the cluster. ** URI Use the following URI to obtain a Node Object, from a node identified by the {nodeid} value. ------ * http:///ws/v1/cluster/nodes/{nodeid} ------ ** HTTP Operations Supported ------ * GET ------ ** Query Parameters Supported ------ None ------ ** Elements of the object *---------------+--------------+-------------------------------+ || Item || Data Type || Description | *---------------+--------------+-------------------------------+ | rack | string | The rack location of this node | *---------------+--------------+-------------------------------+ | state | string | State of the node - valid values are: NEW, RUNNING, UNHEALTHY, DECOMMISSIONED, LOST, REBOOTED | *---------------+--------------+-------------------------------+ | id | string | The node id | *---------------+--------------+-------------------------------+ | nodeHostName | string | The host name of the node| *---------------+--------------+-------------------------------+ | nodeHTTPAddress | string | The nodes HTTP address| *---------------+--------------+-------------------------------+ | healthStatus | string | The health status of the node - Healthy or Unhealthy | *---------------+--------------+-------------------------------+ | healthReport | string | A detailed health report | *---------------+--------------+-------------------------------+ | lastHealthUpdate | long | The last time the node reported its health (in ms since epoch)| *---------------+--------------+-------------------------------+ | usedMemoryMB | long | The total about of memory currently used on the node (in MB)| *---------------+--------------+-------------------------------+ | availMemoryMB | long | The total amount of memory currently available on the node (in MB)| *---------------+--------------+-------------------------------+ | numContainers | int | The total number of containers currently running on the node| *---------------+--------------+-------------------------------+ ** Response Examples <> HTTP Request: ------ GET http:///ws/v1/cluster/nodes/h2:1235 ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/json Transfer-Encoding: chunked Server: Jetty(6.1.26) +---+ Response Body: +---+ { "node": { "rack":"\/default-rack", "state":"NEW", "id":"h2:1235", "nodeHostName":"h2", "nodeHTTPAddress":"h2:2", "healthStatus":"Healthy", "lastHealthUpdate":1324056895432, "healthReport":"Healthy", "numContainers":0, "usedMemoryMB":0, "availMemoryMB":5120 } } +---+ <> HTTP Request: ------ GET http:///ws/v1/cluster/node/h2:1235 Accept: application/xml ------ Response Header: +---+ HTTP/1.1 200 OK Content-Type: application/xml Content-Length: 552 Server: Jetty(6.1.26) +---+ Response Body: +---+ /default-rack NEW h2:1235 h2 h2:2 Healthy 1324333268447 Healthy 0 0 5120 +---+