|
@@ -1,15 +1,13 @@
|
|
package client
|
|
package client
|
|
|
|
|
|
import (
|
|
import (
|
|
- "encoding/json"
|
|
|
|
"fmt"
|
|
"fmt"
|
|
- "net/url"
|
|
|
|
- "time"
|
|
|
|
|
|
+ "io"
|
|
|
|
|
|
- "github.com/docker/docker/api/types"
|
|
|
|
|
|
+ "github.com/docker/docker/api/client/lib"
|
|
Cli "github.com/docker/docker/cli"
|
|
Cli "github.com/docker/docker/cli"
|
|
flag "github.com/docker/docker/pkg/mflag"
|
|
flag "github.com/docker/docker/pkg/mflag"
|
|
- "github.com/docker/docker/pkg/timeutils"
|
|
|
|
|
|
+ "github.com/docker/docker/pkg/stdcopy"
|
|
)
|
|
)
|
|
|
|
|
|
var validDrivers = map[string]bool{
|
|
var validDrivers = map[string]bool{
|
|
@@ -32,47 +30,34 @@ func (cli *DockerCli) CmdLogs(args ...string) error {
|
|
|
|
|
|
name := cmd.Arg(0)
|
|
name := cmd.Arg(0)
|
|
|
|
|
|
- serverResp, err := cli.call("GET", "/containers/"+name+"/json", nil, nil)
|
|
|
|
|
|
+ c, err := cli.client.ContainerInspect(name)
|
|
if err != nil {
|
|
if err != nil {
|
|
return err
|
|
return err
|
|
}
|
|
}
|
|
|
|
|
|
- var c types.ContainerJSON
|
|
|
|
- if err := json.NewDecoder(serverResp.body).Decode(&c); err != nil {
|
|
|
|
- return err
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
if !validDrivers[c.HostConfig.LogConfig.Type] {
|
|
if !validDrivers[c.HostConfig.LogConfig.Type] {
|
|
return fmt.Errorf("\"logs\" command is supported only for \"json-file\" and \"journald\" logging drivers (got: %s)", c.HostConfig.LogConfig.Type)
|
|
return fmt.Errorf("\"logs\" command is supported only for \"json-file\" and \"journald\" logging drivers (got: %s)", c.HostConfig.LogConfig.Type)
|
|
}
|
|
}
|
|
|
|
|
|
- v := url.Values{}
|
|
|
|
- v.Set("stdout", "1")
|
|
|
|
- v.Set("stderr", "1")
|
|
|
|
-
|
|
|
|
- if *since != "" {
|
|
|
|
- ts, err := timeutils.GetTimestamp(*since, time.Now())
|
|
|
|
- if err != nil {
|
|
|
|
- return err
|
|
|
|
- }
|
|
|
|
- v.Set("since", ts)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if *times {
|
|
|
|
- v.Set("timestamps", "1")
|
|
|
|
|
|
+ options := lib.ContainerLogsOptions{
|
|
|
|
+ ContainerID: name,
|
|
|
|
+ ShowStdout: true,
|
|
|
|
+ ShowStderr: true,
|
|
|
|
+ Since: *since,
|
|
|
|
+ Timestamps: *times,
|
|
|
|
+ Follow: *follow,
|
|
|
|
+ Tail: *tail,
|
|
}
|
|
}
|
|
-
|
|
|
|
- if *follow {
|
|
|
|
- v.Set("follow", "1")
|
|
|
|
|
|
+ responseBody, err := cli.client.ContainerLogs(options)
|
|
|
|
+ if err != nil {
|
|
|
|
+ return err
|
|
}
|
|
}
|
|
- v.Set("tail", *tail)
|
|
|
|
|
|
+ defer responseBody.Close()
|
|
|
|
|
|
- sopts := &streamOpts{
|
|
|
|
- rawTerminal: c.Config.Tty,
|
|
|
|
- out: cli.out,
|
|
|
|
- err: cli.err,
|
|
|
|
|
|
+ if c.Config.Tty {
|
|
|
|
+ _, err = io.Copy(cli.out, responseBody)
|
|
|
|
+ } else {
|
|
|
|
+ _, err = stdcopy.StdCopy(cli.out, cli.err, responseBody)
|
|
}
|
|
}
|
|
-
|
|
|
|
- _, err = cli.stream("GET", "/containers/"+name+"/logs?"+v.Encode(), sopts)
|
|
|
|
return err
|
|
return err
|
|
}
|
|
}
|