使用Docker Go SDK时如何打印`bash -xc`命令?

问题描述

我正在尝试使用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 (将#修改为@)