github.com/a4a881d4/docker@v1.9.0-rc2/api/client/top.go (about) 1 package client 2 3 import ( 4 "encoding/json" 5 "fmt" 6 "net/url" 7 "strings" 8 "text/tabwriter" 9 10 "github.com/docker/docker/api/types" 11 Cli "github.com/docker/docker/cli" 12 flag "github.com/docker/docker/pkg/mflag" 13 ) 14 15 // CmdTop displays the running processes of a container. 16 // 17 // Usage: docker top CONTAINER 18 func (cli *DockerCli) CmdTop(args ...string) error { 19 cmd := Cli.Subcmd("top", []string{"CONTAINER [ps OPTIONS]"}, Cli.DockerCommands["top"].Description, true) 20 cmd.Require(flag.Min, 1) 21 22 cmd.ParseFlags(args, true) 23 24 val := url.Values{} 25 if cmd.NArg() > 1 { 26 val.Set("ps_args", strings.Join(cmd.Args()[1:], " ")) 27 } 28 29 serverResp, err := cli.call("GET", "/containers/"+cmd.Arg(0)+"/top?"+val.Encode(), nil, nil) 30 if err != nil { 31 return err 32 } 33 34 defer serverResp.body.Close() 35 36 procList := types.ContainerProcessList{} 37 if err := json.NewDecoder(serverResp.body).Decode(&procList); err != nil { 38 return err 39 } 40 41 w := tabwriter.NewWriter(cli.out, 20, 1, 3, ' ', 0) 42 fmt.Fprintln(w, strings.Join(procList.Titles, "\t")) 43 44 for _, proc := range procList.Processes { 45 fmt.Fprintln(w, strings.Join(proc, "\t")) 46 } 47 w.Flush() 48 return nil 49 }