1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00

support docker node ps multiNodes

Signed-off-by: allencloud <allen.sun@daocloud.io>
This commit is contained in:
allencloud 2016-09-04 15:38:50 +08:00
parent 81090c9455
commit af4461ad29
4 changed files with 49 additions and 25 deletions

View file

@ -1,7 +1,11 @@
package node package node
import ( import (
"fmt"
"strings"
"github.com/docker/docker/api/types" "github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/swarm"
"github.com/docker/docker/cli" "github.com/docker/docker/cli"
"github.com/docker/docker/cli/command" "github.com/docker/docker/cli/command"
"github.com/docker/docker/cli/command/idresolver" "github.com/docker/docker/cli/command/idresolver"
@ -12,7 +16,7 @@ import (
) )
type psOptions struct { type psOptions struct {
nodeID string nodeIDs []string
noResolve bool noResolve bool
noTrunc bool noTrunc bool
filter opts.FilterOpt filter opts.FilterOpt
@ -22,14 +26,14 @@ func newPsCommand(dockerCli *command.DockerCli) *cobra.Command {
opts := psOptions{filter: opts.NewFilterOpt()} opts := psOptions{filter: opts.NewFilterOpt()}
cmd := &cobra.Command{ cmd := &cobra.Command{
Use: "ps [OPTIONS] [NODE]", Use: "ps [OPTIONS] [NODE...]",
Short: "List tasks running on a node, defaults to current node", Short: "List tasks running on one or more nodes, defaults to current node",
Args: cli.RequiresRangeArgs(0, 1), Args: cli.RequiresMinArgs(0),
RunE: func(cmd *cobra.Command, args []string) error { RunE: func(cmd *cobra.Command, args []string) error {
opts.nodeID = "self" opts.nodeIDs = []string{"self"}
if len(args) != 0 { if len(args) != 0 {
opts.nodeID = args[0] opts.nodeIDs = args
} }
return runPs(dockerCli, opts) return runPs(dockerCli, opts)
@ -47,23 +51,43 @@ func runPs(dockerCli *command.DockerCli, opts psOptions) error {
client := dockerCli.Client() client := dockerCli.Client()
ctx := context.Background() ctx := context.Background()
nodeRef, err := Reference(ctx, client, opts.nodeID) var (
if err != nil { errs []string
return nil tasks []swarm.Task
} )
node, _, err := client.NodeInspectWithRaw(ctx, nodeRef)
if err != nil { for _, nodeID := range opts.nodeIDs {
return err nodeRef, err := Reference(ctx, client, nodeID)
if err != nil {
errs = append(errs, err.Error())
continue
}
node, _, err := client.NodeInspectWithRaw(ctx, nodeRef)
if err != nil {
errs = append(errs, err.Error())
continue
}
filter := opts.filter.Value()
filter.Add("node", node.ID)
nodeTasks, err := client.TaskList(ctx, types.TaskListOptions{Filter: filter})
if err != nil {
errs = append(errs, err.Error())
continue
}
tasks = append(tasks, nodeTasks...)
} }
filter := opts.filter.Value() if err := task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve), opts.noTrunc); err != nil {
filter.Add("node", node.ID) errs = append(errs, err.Error())
tasks, err := client.TaskList(
ctx,
types.TaskListOptions{Filter: filter})
if err != nil {
return err
} }
return task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve), opts.noTrunc) if len(errs) > 0 {
return fmt.Errorf("%s", strings.Join(errs, "\n"))
}
return nil
} }

View file

@ -792,7 +792,7 @@ __docker_node_commands() {
"ls:List nodes in the swarm" "ls:List nodes in the swarm"
"promote:Promote a node as manager in the swarm" "promote:Promote a node as manager in the swarm"
"rm:Remove one or more nodes from the swarm" "rm:Remove one or more nodes from the swarm"
"ps:List tasks running on a node, defaults to current node" "ps:List tasks running on one or more nodes, defaults to current node"
"update:Update a node" "update:Update a node"
) )
_describe -t docker-node-commands "docker node command" _docker_node_subcommands _describe -t docker-node-commands "docker node command" _docker_node_subcommands

View file

@ -115,7 +115,7 @@ read the [`dockerd`](dockerd.md) reference page.
| [node demote](node_demote.md) | Demotes an existing manager so that it is no longer a manager | | [node demote](node_demote.md) | Demotes an existing manager so that it is no longer a manager |
| [node inspect](node_inspect.md) | Inspect a node in the swarm | | [node inspect](node_inspect.md) | Inspect a node in the swarm |
| [node update](node_update.md) | Update attributes for a node | | [node update](node_update.md) | Update attributes for a node |
| [node ps](node_ps.md) | List tasks running on a node | | [node ps](node_ps.md) | List tasks running on one or more nodes |
| [node ls](node_ls.md) | List nodes in the swarm | | [node ls](node_ls.md) | List nodes in the swarm |
| [node rm](node_rm.md) | Remove one or more nodes from the swarm | | [node rm](node_rm.md) | Remove one or more nodes from the swarm |

View file

@ -12,9 +12,9 @@ parent = "smn_cli"
# node ps # node ps
```markdown ```markdown
Usage: docker node ps [OPTIONS] [NODE] Usage: docker node ps [OPTIONS] [NODE...]
List tasks running on a node, defaults to current node. List tasks running on one or more nodes, defaults to current node.
Options: Options:
-a, --all Display all instances -a, --all Display all instances