Skip to content

Latest commit

 

History

History
48 lines (35 loc) · 1.79 KB

buildx_dial-stdio.md

File metadata and controls

48 lines (35 loc) · 1.79 KB

docker buildx dial-stdio

Proxy current stdio streams to builder instance

Options

Name Type Default Description
--builder string Override the configured builder instance
-D, --debug bool Enable debug logging
--platform string Target platform: this is used for node selection
--progress string quiet Set type of progress output (auto, plain, tty, rawjson). Use plain to show container output

Description

dial-stdio uses the stdin and stdout streams of the command to proxy to the configured builder instance. It is not intended to be used by humans, but rather by other tools that want to interact with the builder instance via BuildKit API.

Examples

Example go program that uses the dial-stdio command wire up a buildkit client. This is for example use only and may not be suitable for production use.

client.New(ctx, "", client.WithContextDialer(func(context.Context, string) (net.Conn, error) {
    c1, c2 := net.Pipe()
    cmd := exec.Command("docker", "buildx", "dial-stdio")
    cmd.Stdin = c1
    cmd.Stdout = c1

    if err := cmd.Start(); err != nil {
        c1.Close()
        c2.Close()
        return nil, err
    }

    go func() {
        cmd.Wait()
        c2.Close()
    }()

    return c2
}))