问题描述
我正在尝试使用Go SDK从Docker内部打印Bash命令本身。以下作品:
docker run ubuntu /bin/bash -xc "echo test
echo hello
"
并打印以下结果:
+ echo test
test
+ echo hello
hello
但是,当使用Docker SDK在Go应用程序中执行相同的操作时,我得到的是命令的结果,但不是命令本身(这是default Docker SDK example的修改,可以使用多行命令):
package main
import (
"context"
"io"
"os"
"log"
"github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/container"
"github.com/docker/docker/client"
"github.com/docker/docker/pkg/stdcopy"
)
func main() {
ctx := context.Background()
cli,err := client.NewClientWithOpts(client.FromEnv,client.WithAPIVersionNegotiation())
if err != nil {
panic(err)
}
script := `
echo hello
echo test
`
reader,err := cli.ImagePull(ctx,"docker.io/library/ubuntu",types.ImagePullOptions{})
if err != nil {
panic(err)
}
io.copy(os.Stdout,reader)
resp,err := cli.ContainerCreate(ctx,&container.Config{
Image: "ubuntu",Cmd: []string{"/bin/bash","-c",script},},nil,"")
if err != nil {
panic(err)
}
if err := cli.ContainerStart(ctx,resp.ID,types.ContainerStartOptions{}); err != nil {
panic(err)
}
statusCh,errCh := cli.ContainerWait(ctx,container.WaitConditionNotRunning)
select {
case err := <-errCh:
if err != nil {
panic(err)
}
case <-statusCh:
}
out,err := cli.ContainerLogs(ctx,types.ContainerLogsOptions{ShowStdout: true})
if err != nil {
panic(err)
}
stdcopy.Stdcopy(os.Stdout,os.Stderr,out)
}
是否可以从Docker日志中获取这些值?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)