open-nomad/command/status.go

165 lines
3.6 KiB
Go
Raw Normal View History

2015-09-11 07:38:15 +00:00
package command
import (
"fmt"
"strings"
"github.com/ryanuber/columnize"
)
type StatusCommand struct {
Meta
2015-09-11 07:38:15 +00:00
}
func (c *StatusCommand) Help() string {
helpText := `
2015-09-11 17:00:55 +00:00
Usage: nomad status [options] [job]
2015-09-11 07:38:15 +00:00
2015-09-13 18:39:49 +00:00
Display status information about jobs. If no job ID is given,
2015-09-11 17:00:55 +00:00
a list of all known jobs will be dumped.
2015-09-11 07:38:15 +00:00
General Options:
2015-09-11 07:38:15 +00:00
` + generalOptionsUsage() + `
Status Options:
-short
Display short output. Used only when a single job is being
queried, and drops verbose information about allocations
and evaluations.
`
2015-09-11 07:38:15 +00:00
return strings.TrimSpace(helpText)
}
func (c *StatusCommand) Synopsis() string {
2015-09-13 18:39:49 +00:00
return "Display status information about jobs"
2015-09-11 07:38:15 +00:00
}
func (c *StatusCommand) Run(args []string) int {
var short bool
flags := c.Meta.FlagSet("status", FlagSetClient)
2015-09-11 07:38:15 +00:00
flags.Usage = func() { c.Ui.Output(c.Help()) }
flags.BoolVar(&short, "short", false, "")
2015-09-11 07:38:15 +00:00
if err := flags.Parse(args); err != nil {
return 1
}
// Check that we either got no jobs or exactly one.
args = flags.Args()
if len(args) > 1 {
2015-09-11 07:38:15 +00:00
c.Ui.Error(c.Help())
return 1
}
// Get the HTTP client
client, err := c.Meta.Client()
2015-09-11 07:38:15 +00:00
if err != nil {
c.Ui.Error(fmt.Sprintf("Error initializing client: %s", err))
2015-09-11 07:38:15 +00:00
return 1
}
// Invoke list mode if no job ID.
if len(args) == 0 {
2015-09-11 07:38:15 +00:00
jobs, _, err := client.Jobs().List(nil)
if err != nil {
c.Ui.Error(fmt.Sprintf("Error querying jobs: %s", err))
2015-09-11 07:38:15 +00:00
return 1
}
2015-09-11 17:00:55 +00:00
// No output if we have no jobs
if len(jobs) == 0 {
return 0
}
2015-09-13 18:39:49 +00:00
out := make([]string, len(jobs)+1)
out[0] = "ID|Type|Priority|Status"
2015-09-13 18:39:49 +00:00
for i, job := range jobs {
out[i+1] = fmt.Sprintf("%s|%s|%d|%s",
2015-09-11 07:38:15 +00:00
job.ID,
job.Type,
job.Priority,
2015-09-13 18:39:49 +00:00
job.Status)
2015-09-11 07:38:15 +00:00
}
c.Ui.Output(columnize.SimpleFormat(out))
return 0
}
// Try querying the job
jobID := args[0]
2015-09-11 07:38:15 +00:00
job, _, err := client.Jobs().Info(jobID, nil)
if err != nil {
c.Ui.Error(fmt.Sprintf("Error querying job: %s", err))
2015-09-11 07:38:15 +00:00
return 1
}
// Make the column config so we can dump k = v pairs
columnConf := columnize.DefaultConfig()
columnConf.Glue = " = "
2015-09-11 07:38:15 +00:00
// Format the job info
basic := []string{
fmt.Sprintf("ID | %s", job.ID),
fmt.Sprintf("Name | %s", job.Name),
fmt.Sprintf("Type | %s", job.Type),
fmt.Sprintf("Priority | %d", job.Priority),
fmt.Sprintf("Datacenters | %s", strings.Join(job.Datacenters, ",")),
fmt.Sprintf("Status | %s", job.Status),
}
var evals, allocs []string
if !short {
// Query the evaluations
jobEvals, _, err := client.Jobs().Evaluations(jobID, nil)
if err != nil {
c.Ui.Error(fmt.Sprintf("Error querying job evaluations: %s", err))
return 1
}
// Query the allocations
jobAllocs, _, err := client.Jobs().Allocations(jobID, nil)
if err != nil {
c.Ui.Error(fmt.Sprintf("Error querying job allocations: %s", err))
return 1
}
// Format the evals
evals = make([]string, len(jobEvals)+1)
2015-09-15 20:15:33 +00:00
evals[0] = "ID|Priority|Type|TriggeredBy|NodeID|Status"
for i, eval := range jobEvals {
2015-09-15 20:15:33 +00:00
evals[i+1] = fmt.Sprintf("%s|%d|%s|%s|%s|%s",
eval.ID,
eval.Priority,
eval.Type,
eval.TriggeredBy,
2015-09-15 20:15:33 +00:00
eval.NodeID,
eval.Status)
}
// Format the allocs
allocs = make([]string, len(jobAllocs)+1)
2015-09-15 20:15:33 +00:00
allocs[0] = "ID|EvalID|NodeID|TaskGroup|DesiredStatus|ClientStatus"
for i, alloc := range jobAllocs {
allocs[i+1] = fmt.Sprintf("%s|%s|%s|%s|%s|%s",
alloc.ID,
alloc.EvalID,
2015-09-15 20:15:33 +00:00
alloc.NodeID,
alloc.TaskGroup,
alloc.DesiredStatus,
alloc.ClientStatus)
}
}
// Dump the output
c.Ui.Output(columnize.Format(basic, columnConf))
if !short {
c.Ui.Output("\nEvaluations")
c.Ui.Output(columnize.SimpleFormat(evals))
c.Ui.Output("\nAllocations")
c.Ui.Output(columnize.SimpleFormat(allocs))
}
2015-09-11 07:38:15 +00:00
return 0
}