You are here: Appendices > Appendix G: Integrating Other Resources with Moab > Compute Resource Managers > Wiki Interface
|
|
Appendix W: Wiki Interface Specification, version 1.2 |
Field values must backslash escape the following characters if specified:
'#' ';' ':' (i.e. '\#')
Supported Commands are:
Only nodes updated more recently than <UPDATETIME> will be returned where <UPDATETIME> is specified as the epoch time of interest. Setting <UPDATETIME> to '0' will return information for all nodes. Specify a colon delimited list of NODEID's if specific nodes are desired or use the keyword 'ALL' to receive information for all nodes.
<NODEID> <ATTR>=<VALUE>[;<ATTR>=<VALUE>]...
<ATTR> is one of the names in the table below and the format of <VALUE> is dependent on <ATTR>.
response:
NAME | FORMAT | DEFAULT | DESCRIPTION |
ADISK | <INTEGER> | 0 | Available local disk on node (in MB) |
AFS | <fs id="X" size="X" io="Y" rcount="X" wcount="X" ocount="X"></fs>[...] | 0 | Available filesystem state |
AMEMORY | <INTEGER> | 0 | Available/free RAM on node (in MB) |
APROC | <INTEGER> | 1 | Available processors on node |
ARCH | <STRING> | --- | Compute architecture of node |
ARES | one or more comma delimited <NAME>:<VALUE> pairs (ie, MATLAB:6,COMPILER:100) | --- | Arbitrary consumable resources currently available on the node |
ASWAP | <INTEGER> | 0 | Available swap on node (in MB) |
CDISK | <INTEGER> | 0 | Configured local disk on node (in MB) |
CFS | <STRING> | 0 | Configured filesystem state |
CMEMORY | <INTEGER> | 0 | Configured RAM on node (in MB) |
CPROC | <INTEGER> | 1 | Configured processors on node |
CPULOAD | <DOUBLE> | 0.0 | One minute BSD load average |
CRES | one or more comma delimited <NAME>:<VALUE> pairs (ie, MATLAB:6,COMPILER:100) | --- | Arbitrary consumable resources supported and tracked on the node, ie software licenses or tape drives. |
CSWAP | <INTEGER> | 0 | Configured swap on node (in MB) |
CURRENTTASK | <INTEGER> | 0 | Number of tasks currently active on the node |
EVENT | <STRING> | --- | Event or exception which occurred on the node |
FEATURE | one or more colon delimited <STRING>'s (ie, WIDE:HSM) | --- | Generic attributes, often describing hardware or software features, associated with the node. |
GCOUNTER | <INTEGER> | --- | Current total number of gevent event occurrences since epoch. This value should be monotonically increasing. |
GEVENT | GEVENT[<EVENTNAME>]=<STRING> | --- | Generic event occurrence and context data. |
GMETRIC | GMETRIC[<METRICNAME>]=<DOUBLE> | --- | Current value of generic metric, i.e., 'GMETRIC[temp]=103.5'. |
IDLETIME | <INTEGER> | --- | Number of seconds since last detected keyboard or mouse activity (often used with desktop harvesting) |
MAXTASK | <INTEGER> | <CPROC> | Maximum number of tasks allowed on the node at any given time |
NODEINDEX | <INTEGER> | --- | The node's index |
OS | <STRING> | --- | Operating system running on node |
OSLIST | One or more comma delimited <STRING>'s with quotes if the strIng has spaces (ie. "SAS7 AS3 Core Baseline Build v0.1.0","RedHat AS3-U5Development Build v0.2"). | --- | Operating systems accepted by node |
OTHER | <ATTR>=<VALUE>[,<ATTR>=<VALUE>]... | --- | Opaque node attributes assigned to node |
PARTITION | <STRING> | DEFAULT | Partition to which node belongs |
RACK | <INTEGER> | 0 | Rack location of the node |
SLOT | <INTEGER> | 0 | Slot location of the node |
SPEED | <DOUBLE> | 1.0 | Relative processor speed of the node. For more information, see Node Attributes Speed |
STATE* | one of the following: Idle, Running, Busy, Unknown, Drained, Draining, or Down | Down | State of the node |
UPDATETIME* | <EPOCHTIME> | 0 | Time node information was last updated |
VARATTR | VARATTR=ATTR{=VALUE}[+ATTR{=VALUE}...]
For example: hv1 VARATTR=HVTYPE=ESX hv1 VARATTR=HVTYPE=ESX+AllowVMMigrations hv1 VARATTR=HVTYPE=ESX+NoVMMigrations vm1 VARATTR=CanMigrate vm1 VARATTR=CannotMigrate | --- | Allows you to specify extra attributes for the resource. Supported attributes are: HVTYPE - Specifies the hypervisor type for the given server (e.g. ESX or KVM) NoVMMigrations - Prevents VMs from auto-migrating to or from the given hypervisor (only applies to servers). AllowVMMigrations -Specifies that the given hypervisor is allowed to auto-migrate VMs again (only applies to servers). CannotMigrate - Stops the given VM from auto-migrating (only applies to VMs). CanMigrate - Allows the given VM to auto-migrate again (only applies to VMs).
|
VARIABLE | <ATTR>=<VAL> | --- | Generic variables to be associated with node |
XRES | one or more comma delimited <NAME>:<VALUE> pairs (ie, MATLAB:6,COMPILER:100) | --- | Amount of external usage of a particular generic resource |
* indicates required field
Note: node states have the following definitions:
Busy: | Node is running some jobs and will not accept additional jobs |
Down: | Resource Manager problems have been detected. Node is incapable of running jobs. |
Draining: | Node is responding but will not accept new jobs |
Idle: | Node is ready to run jobs but currently is not running any. |
Running: | Node is running some jobs and will accept additional jobs |
Unknown: | Node is capable of running jobs but the scheduler will need to determine if the node state is actually Idle, Running, or Busy. |
Only jobs updated more recently than <UPDATETIME> will be returned where <UPDATETIME> is specified as the epoch time of interest. Setting <UPDATETIME> to '0' will return information for all jobs. Specify a colon delimited list of JOBID's if information for specific jobs is desired or use the keyword 'ALL' to receive information about all jobs.
SC=<STATUSCODE> ARG=<JOBCOUNT>#<JOBID>:<FIELD>=<VALUE>;[<FIELD>=<VALUE>;]...[#<JOBID>:<FIELD>=<VALUE>;[<FIELD>=<VALUE>;]...]...
or
SC=<STATUSCODE> RESPONSE=<RESPONSE>
FIELD is
either the text name listed below or 'A<FIELDNUM>'
(ie, 'UPDATETIME' or 'A2')
STATUSCODE values:
0 SUCCESS
-1
INTERNAL ERROR
RESPONSE is a statuscode sensitive message describing error or state details
W.1.1.2.3 Wiki Query Workload Example
NAME | FORMAT | DEFAULT | DESCRIPTION |
ACCOUNT | <STRING> | --- | AccountID associated with job |
ARGS | <STRING> | --- | job command-line arguments |
COMMENT | <STRING> | 0 | job resource manager extension arguments including qos, dependencies, reservation constraints, etc |
COMPLETETIME* | <EPOCHTIME> | 0 | time job completed execution |
DDISK | <INTEGER> | 0 | quantity of local disk space (in MB) which must be dedicated to each task of the job |
DGRES | name:value[,name:value] | --- | Dedicated generic resources per task. |
DPROCS | <INTEGER> | 1 | number of processors dedicated per task |
DNETWORK | <STRING> | --- | network adapter which must be dedicated to job |
DSWAP | <INTEGER> | 0 | quantity of virtual memory (swap, in MB) which must be dedicated to each task of the job |
ENDDATE | <EPOCHTIME> | [ANY] | time by which job must complete |
ENV | <STRING> | --- | job environment variables |
EVENT | <EVENT> | --- | event or exception experienced by job |
ERROR | <STRING> | --- | file to contain STDERR |
EXEC | <STRING> | --- | job executable command |
EXITCODE | <INTEGER> | --- | job exit code |
FLAGS | <STRING> | --- | job flags |
GEOMETRY | <STRING> | --- | String describing task geometry required by job |
GNAME* | <STRING> | --- | GroupID under which job will run |
HOSTLIST | comma or colon delimited list of hostnames - suffix the hostlist with a carat (^) to mean superset; suffix with an asterisk (*) to mean subset; otherwise, the hostlist is interpreted as an exact set | [ANY] | list of required hosts on which job must run. (see TASKLIST) |
INPUT | <STRING> | --- | file containing STDIN |
IWD | <STRING> | --- | job's initial working directory |
NAME | <STRING> | --- | User specified name of job |
NODERANGE | <INTEGER>[,<INTEGER>] | --- | Minimum and maximum nodes allowed to be allocated to job. |
NODES | <INTEGER> | 1 | Number of nodes required by job (See Node Definition for more info) |
OUTPUT | <STRING> | --- | file to contain STDOUT |
PARTITIONMASK | one or more colon delimited <STRING>s | [ANY] | list of partitions in which job can run |
PREF | colon delimited list of <STRING>s | --- | List of preferred node features or variables. (See PREF for more information.) |
PRIORITY | <INTEGER> | --- | system priority (absolute or relative - use '+' and '-' to specify relative) |
QOS | <INTEGER> | 0 | quality of service requested |
QUEUETIME* | <EPOCHTIME> | 0 | time job was submitted to resource manager |
RARCH | <STRING> | --- | architecture required by job |
RCLASS | list of bracket enclosed <STRING>:<INTEGER> pairs | --- | list of <CLASSNAME>:<COUNT> pairs indicating type and number of class instances required per task. (ie, '[batch:1]' or '[batch:2][tape:1]') |
RDISK | <INTEGER> | 0 | local disk space (in MB) required to be configured on nodes allocated to the job |
RDISKCMP | one of '>=', '>', '==', '<', or '<=' | >= | local disk comparison (ie, node must have > 2048 MB local disk) |
REJCODE | <INTEGER> | 0 | reason job was rejected |
REJCOUNT | <INTEGER> | 0 | number of times job was rejected |
REJMESSAGE | <STRING> | --- | text description of reason job was rejected |
REQRSV | <STRING> | --- | Name of reservation in which job must run |
RESACCESS | <STRING> | --- | List of reservations in which job can run |
RFEATURES | colon delimited list <STRING>'s | --- | List of features required on nodes |
RMEM | <INTEGER> | 0 | real memory (RAM, in MB) required to be configured on nodes allocated to the job |
RMEMCMP | one of '>=', '>', '==', '<', or '<=' | >= | real memory comparison (ie, node must have >= 512MB RAM) |
RNETWORK | <STRING> | --- | network adapter required by job |
ROPSYS | <STRING> | --- | operating system required by job |
RSOFTWARE | <RESTYPE>[{+|:}<COUNT>] [@<TIMEFRAME>] | --- | software required by job |
RSWAP | <INTEGER> | 0 | virtual memory (swap, in MB) required to be configured on nodes allocated to the job |
RSWAPCMP | one of '>=', '>', '==', '<', or '<=' | >= | virtual memory comparison (ie, node must have ==4096 MB virtual memory) |
SID | <STRING> | --- | system id (global job system owner) |
SJID | <STRING> | --- | system job id (global job id) |
STARTDATE | <EPOCHTIME> | 0 | earliest time job should be allowed to start |
STARTTIME* | <EPOCHTIME> | 0 | time job was started by the resource manager |
STATE* | one of Idle, Running, Hold, Suspended, Completed, or Removed | Idle | State of job |
SUSPENDTIME | <INTEGER> | 0 | Number of seconds job has been suspended |
TARGETBACKLOG | <DOUBLE>[,<DOUBLE>] | --- | Minimum and maximum backlog for application within job. |
TARGETLOAD | <DOUBLE>[,<DOUBLE>] | --- | Minimum and maximum load for application within job. |
TARGETRESPONSETIME | <DOUBLE>[,<DOUBLE>] | --- | Minimum and maximum response time for application within job. |
TARGETTHROUGHPUT | <DOUBLE>[,<DOUBLE>] | --- | Minimum and maximum throughput for application within job. |
TARGETVIOLATIONTIME | <ALLOCATIONTIME> [,<DEALLOCATIONTIME>] where values are specified using the format [[[DD:]HH:]MM:]SS | --- | Amount of time an application performance target must be exceeded before Moab adjusts the resource allocation. By default, Moab allocates/deallocates resources as soon as a performance target violation is detected. |
TASKLIST | one or more comma-delimited <STRING>'s | --- | list of allocated tasks, or in other words, comma-delimited list of node ID's associated with each active task of job (i.e., cl01, cl02, cl01, cl02, cl03) The tasklist is initially selected by the scheduler at the time the StartJob command is issued. The resource manager is then responsible for starting the job on these nodes and maintaining this task distribution information throughout the life of the job. (see HOSTLIST) |
TASKS* | <INTEGER> | 1 | Number of tasks required by job (See Task Definition for more info) |
TASKPERNODE | <INTEGER> | 0 | exact number of tasks required per node |
UNAME* | <STRING> | --- | UserID under which job will run |
UPDATETIME* | <EPOCHTIME> | 0 | Time job was last updated |
WCLIMIT* | [[HH:]MM:]SS | 864000 | walltime required by job |
* indicates required field
Note: Job states have the following definitions:
Completed: | Job has completed |
Hold: | Job is in the queue but is not allowed to run |
Idle: | Job is ready to run |
Removed: | Job has been canceled or otherwise terminated externally |
Running: | Job is currently executing |
Suspended: | job has started but execution has temporarily been suspended |
Note: Completed and canceled jobs should be maintained by the resource manager for a brief time, perhaps 1 to 5 minutes, before being purged. This provides the scheduler time to obtain all final job state information for scheduler statistics.
send CMD=STARTJOB ARG=<JOBID> TASKLIST=<NODEID>[:<NODEID>]...
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message possibly further describing an error or state
send CMD=CANCELJOB ARG=<JOBID> TYPE=<CANCELTYPE>
<CANCELTYPE> is one of the following:
ADMIN
(command initiated by scheduler administrator)
WALLCLOCK (command initiated by scheduler because job exceeded its
specified wallclock limit)
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
send CMD=SUSPENDJOB ARG=<JOBID>
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message possibly further describing an error or state
send CMD=RESUMEJOB ARG=<JOBID>
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
send CMD=REQUEUEJOB ARG=<JOBID>
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
send CMD=SIGNALJOB ARG=<JOBID> ACTION=signal VALUE=<SIGNAL>
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
send CMD=MODIFYJOB ARG=<JOBID> [BANK=name] [NODES=num] [PARTITION=name] [TIMELIMIT=minutes]
receive SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
send
CMD=JOBADDTASK ARG=<JOBID> <NODEID> [<NODEID>]...
receive
SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message possibly further describing an error or state
send
CMD=JOBREMOVETASK ARG=<JOBID> <TASKID> [<TASKID>]...
receive
SC=<STATUSCODE> RESPONSE=<RESPONSE>
STATUSCODE >= 0
indicates SUCCESS
STATUSCODE < 0
indicates FAILURE
RESPONSE is a
text message further describing an error or state
Copyright © 2012 Adaptive Computing Enterprises, Inc.®