The various Tractor components communicate using HTTP requests. Most responses to queries are JSON-formatted data dictionaries.
Here is a summary of the query URLs and their replies:
To start a Dashboard session, direct your web browswer to:
Login, creating an authenticated session necessary for some types of control operations:
Retire a job, deleting it from the active assignment queue and dashboards:
Restore a previously deleted job, if the underlying job data is still present:
http://ENGINE/Tractor/queue?q=jrestore&jid=1234&tsid=sssRetry all tasks with errors in a particular job:
http://ENGINE/Tractor/queue?q=jretry&jid=1234&tsubset=error&tsid=sssStop and Requeue all currently active tasks in a particular job:
http://ENGINE/Tractor/queue?q=jretry&jid=1234&&tsubset=active&tsid=sssRetry a specific task, e.g. tid=22, in a job:
http://ENGINE/Tractor/queue?q=jretry&jid=1234&tsubset=22&tsid=sssStop and Requeue all currently active tasks on a particular blade:
http://ENGINE/Tractor/queue?q=ejectall&blade=host/addr&tsid=sssSkip a specific task in a job, allowing its parent to continue:
Completely restart (respool) an entire job:
http://ENGINE/Tractor/queue?q=jrestart&jid=1234&&tsid=sssInterrupt a running job, kill active commands and pause to prevent further dispatching:
http://ENGINE/Tractor/queue?q=jinterrupt&jid=1234&tsid=sssInterrupt a specific task, leaving that task in error state while other tasks continue to run:
List the users who have previously spooled jobs:
http://ENGINE/Tractor/monitor?q=usersList the jobs currently queued for a particular user:
Get the task tree for a particular job:
http://ENGINE/Tractor/monitor?q=jtree&jid=1234List the commands associated with a task:
http://ENGINE/Tractor/monitor?q=taskdetails&jid=1234&tid=11Get the URL for the logs from a particular task:
http://ENGINE/Tractor/monitor?q=tasklogs&owner=name&jid=1234&tid=11General job attribute editing - Attributes entries listed in a job's
jobinfo.json dictionary can be changed using an http URL of the form:
/Tractor/queue?q=jattr&set_ATTRNAME=VALUE&jid=NNNN&tsid=sss
Similarly, attributes at the command-level can be changed using the "q=cattr&cid=..." variant (note: only set_service is supported at this time):
/Tractor/queue?q=cattr&set_ATTRNAME=VALUE&jid=NNNN&cid=CCCC&tsid=sss
Note that crews.config can specify permissions that restrict editing of particular attributes to specific crews, i.e. Wranglers only.
Change the job-level Service Key requirements:
http://ENGINE/Tractor/queue?q=jattr&jid=5678&set_service=someKey&tsid=sssReprioritize a job:
http://ENGINE/Tractor/queue?q=jattr&jid=5678&set_priority=12.34&tsid=sssSuspend new dispatching in a job:
http://ENGINE/Tractor/queue?q=jattr&jid=5678&set_pause=1&tsid=sss
Use "&set_pause=0" to unpause the job. This type of "pause" suspends new task dispatching - the job will be skipped during blade assignment passes until unpaused. Any already running tasks from that job will continue to run.
There are several files of user specific information stored in the user area below the tractor spool folder. The following queries allow the UI to save and retrieve these files.
List all stored filters for user of specified type:
http://ENGINE/Tractor/monitor?q=filters&user=name&type=filtertypeRetrieve a user's named filter:
http://ENGINE/Tractor/monitor?q=getfilter&user=name&key=filternameStore a user's named filter:
http://ENGINE/Tractor/monitor?q=putfilter&user=name&key=filternameRetrieve user's preference information:
http://ENGINE/Tractor/monitor?q=getpreference&user=name&key=filenameStore a user's preference information:
http://ENGINE/Tractor/monitor?q=putpreference&user=name&key=filenameDelete a user's preference information:
http://ENGINE/Tractor/monitor?q=delpreference&user=name&key=filenameRetrieve user's session file:
http://ENGINE/Tractor/monitor?q=getsession&user=name&key=filenameStore a user's session file:
http://ENGINE/Tractor/monitor?q=putsession&user=name&key=filenameDelete a user's session file:
http://ENGINE/Tractor/monitor?q=delsession&user=name&key=filenameRetrieve a list of available file rule definitions:
http://ENGINE/Tractor/monitor?q=filterrules&type=filtertypeReload configuration files (blade, crews, limits):
http://ENGINE/Tractor/ctrl?q=reconfigureReload a single configuration file, for example: limits.config
http://ENGINE/Tractor/ctrl?q=reconfigure&file=limits.configQuery basic engine state:
http://ENGINE/Tractor/ctrl?q=statusQuery current active limit tallies:
http://ENGINE/Tractor/queue?q=limits
NOTE: this query is relatively expensive, it locks all threads. Add &full=1 to also include zero-valued "transitory" limits not defined in limits.config:**
Query unrolled crew definitions:
Query the current Dispatching Tier definitions:
Query unrolled blade profile definitions:
http://ENGINE/Tractor/config?q=get&file=blade.configList recently connected Dashboard users (session mailboxes):
http://ENGINE/Tractor/monitor?q=mboxesTrace engine assignment decisions:
http://ENGINE/Tractor/ctrl?q=tracer&fmt=plain -- next assignment pass
add &t=bbbb -- for blade named bbbb add &t=jjjj -- for job with jid jjjj
Remove an old entry from the displayed list of active blades:
http://ENGINE/Tractor/btrack?q=delist&id=hhhhh/aa.aa.aa.aa
where hhhhh is the blade's hostname and aa.aa.aa.aa is the blade's current tcp/ip address.
Diagnostic: query engine internal message queue lengths:
http://ENGINE/Tractor/ctrl?q=status&qlen=1
NOTE: this query is relatively expensive, it locks all threads.
Engine log level: change the logging threshold level of the engine's own diagnostic logs:
http://ENGINE/Tractor/ctrl?q=loglevel&v=debug
Recognized level names are: severe, notice, info, debug, trace
Engine database contexts: bounce the engine's own internal client connections to the database server:
http://ENGINE/Tractor/ctrl?q=dbreconnectList all of the currently connected blades, with a recent status snapshot:
http://ENGINE/Tractor/monitor?q=bladesStop and Requeue all currently active tasks on a particular blade:
http://ENGINE/Tractor/queue?q=ejectall&blade=host/addr&tsid=sssQuery the engine for its information on a specific blade:
http://ENGINE/Tractor/monitor?q=bdetails&b=NAMEQuery the engine for blade information, and include results from an (expensive) direct probe of the blade itself: http://ENGINE/Tractor/monitor?q=bdetails&b=NAME&probe=1
Use this query cautiously, especially in scripts, since it can cause processing delays on the engine as it waits for the blade response -- especially when probing blades that are slow to respond. In this form of the query, the NAME parameter can be "hostname" or "hostname/address". The address portion is historical and is ignored, the engine derives blade addresses from the last entry in the blade database.
Query the current state of a blade directly:
http://BLADE/blade/statusChange the NIMBY state of a blade, via the engine:
First, send a login request to receive a session ID (tsid), then:
http://ENGINE/Tractor/ctrl?q=battribute&tsid=SSS&b=BBB&nimby=NNN
where:
Change the NIMBY state of a blade via direct http connection to the blade:
http://BLADE/blade/ctrl?nimby=NNN
Where NNN is the same as for the engine proxy case, above. Note that this direct type of connection may be disallowed by the NimbyConnectPolicy setting in blade.config.
Get the most recent engine health statistics:
http://ENGINE/Tractor/monitor?q=statistics
The query returns various tractor-engine performance and status metrics. The currently provided values are intended to give administrators a quick set of engine "vital signs" to check when looking at overall Tractor health or for engine hot spots.
The statistics report is organized as a JSON dictionary. Each key in the dictionary represents one type of metric. The value field in the dictionary for each key is an array of recent samples for that metric.
The current dictionary metrics names are listed here. The list may evolve over time.
Get a recent history of engine statistics:
http://ENGINE/Tractor/monitor?q=statslog
This query is like q=statistics, above, but it returns several minutes worth of samples for each metric.
Note: for continuous monitoring add "&stats=1" to your recurring q=subscribe request; statistics will arrive as 's' mbox messages.
The last entry in each array is the most recent sample. The engine maintains a simple ring buffer of these samples, so on the next update the first array element is dropped and all of the other samples appear to "shift left" with a new value appearing at the end. The statslog query returns all of the samples in the buffer so that a UI can generate a complete graph from a single query.