ps.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package service
  2. import (
  3. "github.com/docker/docker/api/types"
  4. "github.com/docker/docker/api/types/swarm"
  5. "github.com/docker/docker/cli"
  6. "github.com/docker/docker/cli/command"
  7. "github.com/docker/docker/cli/command/idresolver"
  8. "github.com/docker/docker/cli/command/node"
  9. "github.com/docker/docker/cli/command/task"
  10. "github.com/docker/docker/opts"
  11. "github.com/spf13/cobra"
  12. "golang.org/x/net/context"
  13. )
  14. type psOptions struct {
  15. serviceID string
  16. all bool
  17. quiet bool
  18. noResolve bool
  19. noTrunc bool
  20. filter opts.FilterOpt
  21. }
  22. func newPsCommand(dockerCli *command.DockerCli) *cobra.Command {
  23. opts := psOptions{filter: opts.NewFilterOpt()}
  24. cmd := &cobra.Command{
  25. Use: "ps [OPTIONS] SERVICE",
  26. Short: "List the tasks of a service",
  27. Args: cli.ExactArgs(1),
  28. RunE: func(cmd *cobra.Command, args []string) error {
  29. opts.serviceID = args[0]
  30. return runPS(dockerCli, opts)
  31. },
  32. }
  33. flags := cmd.Flags()
  34. flags.BoolVarP(&opts.quiet, "quiet", "q", false, "Only display task IDs")
  35. flags.BoolVar(&opts.noTrunc, "no-trunc", false, "Do not truncate output")
  36. flags.BoolVar(&opts.noResolve, "no-resolve", false, "Do not map IDs to Names")
  37. flags.VarP(&opts.filter, "filter", "f", "Filter output based on conditions provided")
  38. flags.BoolVarP(&opts.all, "all", "a", false, "Show all tasks (default shows tasks that are or will be running)")
  39. return cmd
  40. }
  41. func runPS(dockerCli *command.DockerCli, opts psOptions) error {
  42. client := dockerCli.Client()
  43. ctx := context.Background()
  44. service, _, err := client.ServiceInspectWithRaw(ctx, opts.serviceID)
  45. if err != nil {
  46. return err
  47. }
  48. filter := opts.filter.Value()
  49. filter.Add("service", service.ID)
  50. if filter.Include("node") {
  51. nodeFilters := filter.Get("node")
  52. for _, nodeFilter := range nodeFilters {
  53. nodeReference, err := node.Reference(ctx, client, nodeFilter)
  54. if err != nil {
  55. return err
  56. }
  57. filter.Del("node", nodeFilter)
  58. filter.Add("node", nodeReference)
  59. }
  60. }
  61. if !opts.all && !filter.Include("desired-state") {
  62. filter.Add("desired-state", string(swarm.TaskStateRunning))
  63. filter.Add("desired-state", string(swarm.TaskStateAccepted))
  64. }
  65. tasks, err := client.TaskList(ctx, types.TaskListOptions{Filters: filter})
  66. if err != nil {
  67. return err
  68. }
  69. if opts.quiet {
  70. return task.PrintQuiet(dockerCli, tasks)
  71. }
  72. return task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve), opts.noTrunc)
  73. }