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:
parent
81090c9455
commit
af4461ad29
4 changed files with 49 additions and 25 deletions
|
@ -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 (
|
||||||
|
errs []string
|
||||||
|
tasks []swarm.Task
|
||||||
|
)
|
||||||
|
|
||||||
|
for _, nodeID := range opts.nodeIDs {
|
||||||
|
nodeRef, err := Reference(ctx, client, nodeID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil
|
errs = append(errs, err.Error())
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
node, _, err := client.NodeInspectWithRaw(ctx, nodeRef)
|
node, _, err := client.NodeInspectWithRaw(ctx, nodeRef)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
errs = append(errs, err.Error())
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
filter := opts.filter.Value()
|
filter := opts.filter.Value()
|
||||||
filter.Add("node", node.ID)
|
filter.Add("node", node.ID)
|
||||||
tasks, err := client.TaskList(
|
|
||||||
ctx,
|
nodeTasks, err := client.TaskList(ctx, types.TaskListOptions{Filter: filter})
|
||||||
types.TaskListOptions{Filter: filter})
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
errs = append(errs, err.Error())
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
return task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve), opts.noTrunc)
|
tasks = append(tasks, nodeTasks...)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve), opts.noTrunc); err != nil {
|
||||||
|
errs = append(errs, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(errs) > 0 {
|
||||||
|
return fmt.Errorf("%s", strings.Join(errs, "\n"))
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 |
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Reference in a new issue