Bastion API for jobs
Bastion API documentation for jobs
Jobs
- GET /jobs
Get the list of jobs in the cluster
- Request Headers:
waitIndex – The wait index is used to monitor the jobs with a long pull.
- Response JSON Object:
[] (object) –
[].name (string) – The job name.
[].status (string) – The job status.
[].autostart (boolean) – If the job start when starting all jobs.
[].byCluster (boolean) – If the job must start for each cluster.
[].taskGroups[] (object) – An array of task group.
[].taskGroups[].name (string) – The task group name.
[].taskGroups[].count (integer) – The required number of task group to run.
[].taskGroups[].summary.queued (integer) –
[].taskGroups[].summary.complete (integer) –
[].taskGroups[].summary.failed (integer) –
[].taskGroups[].summary.running (integer) –
[].taskGroups[].summary.starting (integer) –
[].taskGroups[].summary.lost (integer) –
[].hclv1 (boolean) – If the job template is using HCLv1.
- Response Headers:
waitIndex – undefined
Example response:
[ { "name": "jobName", "status": "running", "autostart": true, "byCluster": true, "taskGroups": [ { "name": "takGroupName", "count": 0, "summary": { "queued": 0, "complete": 0, "failed": 0, "running": 0, "starting": 0, "lost": 0 } } ], "hclv1": false } ]
- GET /job/{jobName}/summary
Get the job summary
- Parameters:
jobName – The job name
- Response JSON Object:
name (string) – The job name.
status (string) – The job status.
autostart (boolean) – If the job start when starting all jobs.
byCluster (boolean) – If the job must start for each cluster.
taskGroups[] (object) – An array of task group.
taskGroups[].name (string) – The task group name.
taskGroups[].count (integer) – The required number of task group to run.
taskGroups[].summary.queued (integer) –
taskGroups[].summary.complete (integer) –
taskGroups[].summary.failed (integer) –
taskGroups[].summary.running (integer) –
taskGroups[].summary.starting (integer) –
taskGroups[].summary.lost (integer) –
hclv1 (boolean) – If the job template is using HCLv1.
Example response:
{ "name": "jobName", "status": "running", "autostart": true, "byCluster": true, "taskGroups": [ { "name": "takGroupName", "count": 0, "summary": { "queued": 0, "complete": 0, "failed": 0, "running": 0, "starting": 0, "lost": 0 } } ], "hclv1": false }
- POST /jobs/start/{jobName}
Schedule the job to start, or refresh the job if already started.
Changed in version 1.45.0: Added the capacity to refresh the job and the
force
parameter.- Parameters:
jobName – The job name
- Query Parameters:
force – If the job is already running, force it to update their task counters too with the job definition.
- POST /jobs/stop/{jobName}
Schedule the job to stop
- Parameters:
jobName – The job name
- Query Parameters:
purge – Force the purge the job in Nomad.
- POST /jobs/startall
Schedule or refresh all autostart jobs.
- ..versionchanged:: 1.45.0
Added the ability to refresh the job and the
force
parameter.
- Query Parameters:
force – If the job is already running, force it to update their task counters too with the job definition.
- POST /jobs/stopall
Schedule all jobs to stop
- Query Parameters:
purge – Force the purge the job in Nomad.
- POST /jobs/updatecounts
Increment or decrement a task group count. If count is 0, set it to 0.
- Request JSON Object:
jobID (string) – The name of the job.
taskGroup (string) – The task group.
count (integer) – The count delta. 0 will stop the job.
Example query:
{ "jobID": "jobName", "taskGroup": "taskGrouName", "count": 0 }
- POST /jobs/settaskgroupcount
Set a task group count.
New in version 1.23.0.
- Request JSON Object:
jobID (string) – The name of the job.
taskGroup (string) – The task group.
count (integer) – The value to set the task group count.
Example query:
{ "jobID": "jobName", "taskGroup": "taskGrouName", "count": 0 }