mirror of https://github.com/docker/buildx.git
171 lines
4.2 KiB
Go
171 lines
4.2 KiB
Go
package commands
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"sort"
|
|
"strings"
|
|
"text/tabwriter"
|
|
"time"
|
|
|
|
"github.com/docker/buildx/builder"
|
|
"github.com/docker/buildx/driver"
|
|
"github.com/docker/buildx/util/cobrautil/completion"
|
|
"github.com/docker/buildx/util/platformutil"
|
|
"github.com/docker/cli/cli"
|
|
"github.com/docker/cli/cli/command"
|
|
"github.com/docker/cli/cli/debug"
|
|
"github.com/docker/go-units"
|
|
"github.com/moby/buildkit/util/appcontext"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
type inspectOptions struct {
|
|
bootstrap bool
|
|
builder string
|
|
}
|
|
|
|
func runInspect(dockerCli command.Cli, in inspectOptions) error {
|
|
ctx := appcontext.Context()
|
|
|
|
b, err := builder.New(dockerCli,
|
|
builder.WithName(in.builder),
|
|
builder.WithSkippedValidation(),
|
|
)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
timeoutCtx, cancel := context.WithTimeout(ctx, 20*time.Second)
|
|
defer cancel()
|
|
|
|
nodes, err := b.LoadNodes(timeoutCtx, true)
|
|
if in.bootstrap {
|
|
var ok bool
|
|
ok, err = b.Boot(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if ok {
|
|
nodes, err = b.LoadNodes(timeoutCtx, true)
|
|
}
|
|
}
|
|
|
|
w := tabwriter.NewWriter(os.Stdout, 0, 0, 1, ' ', 0)
|
|
fmt.Fprintf(w, "Name:\t%s\n", b.Name)
|
|
fmt.Fprintf(w, "Driver:\t%s\n", b.Driver)
|
|
if !b.NodeGroup.LastActivity.IsZero() {
|
|
fmt.Fprintf(w, "Last Activity:\t%v\n", b.NodeGroup.LastActivity)
|
|
}
|
|
|
|
if err != nil {
|
|
fmt.Fprintf(w, "Error:\t%s\n", err.Error())
|
|
} else if b.Err() != nil {
|
|
fmt.Fprintf(w, "Error:\t%s\n", b.Err().Error())
|
|
}
|
|
if err == nil {
|
|
fmt.Fprintln(w, "")
|
|
fmt.Fprintln(w, "Nodes:")
|
|
|
|
for i, n := range nodes {
|
|
if i != 0 {
|
|
fmt.Fprintln(w, "")
|
|
}
|
|
fmt.Fprintf(w, "Name:\t%s\n", n.Name)
|
|
fmt.Fprintf(w, "Endpoint:\t%s\n", n.Endpoint)
|
|
|
|
var driverOpts []string
|
|
for k, v := range n.DriverOpts {
|
|
driverOpts = append(driverOpts, fmt.Sprintf("%s=%q", k, v))
|
|
}
|
|
if len(driverOpts) > 0 {
|
|
fmt.Fprintf(w, "Driver Options:\t%s\n", strings.Join(driverOpts, " "))
|
|
}
|
|
|
|
if err := n.Err; err != nil {
|
|
fmt.Fprintf(w, "Error:\t%s\n", err.Error())
|
|
} else {
|
|
fmt.Fprintf(w, "Status:\t%s\n", nodes[i].DriverInfo.Status)
|
|
if len(n.Flags) > 0 {
|
|
fmt.Fprintf(w, "Flags:\t%s\n", strings.Join(n.Flags, " "))
|
|
}
|
|
if nodes[i].Version != "" {
|
|
fmt.Fprintf(w, "Buildkit:\t%s\n", nodes[i].Version)
|
|
}
|
|
fmt.Fprintf(w, "Platforms:\t%s\n", strings.Join(platformutil.FormatInGroups(n.Node.Platforms, n.Platforms), ", "))
|
|
if debug.IsEnabled() {
|
|
fmt.Fprintf(w, "Features:\n")
|
|
features := nodes[i].Driver.Features(ctx)
|
|
featKeys := make([]string, 0, len(features))
|
|
for k := range features {
|
|
featKeys = append(featKeys, string(k))
|
|
}
|
|
sort.Strings(featKeys)
|
|
for _, k := range featKeys {
|
|
fmt.Fprintf(w, "\t%s:\t%t\n", k, features[driver.Feature(k)])
|
|
}
|
|
}
|
|
if len(nodes[i].Labels) > 0 {
|
|
fmt.Fprintf(w, "Labels:\n")
|
|
for _, k := range sortedKeys(nodes[i].Labels) {
|
|
v := nodes[i].Labels[k]
|
|
fmt.Fprintf(w, "\t%s:\t%s\n", k, v)
|
|
}
|
|
}
|
|
for ri, rule := range nodes[i].GCPolicy {
|
|
fmt.Fprintf(w, "GC Policy rule#%d:\n", ri)
|
|
fmt.Fprintf(w, "\tAll:\t%v\n", rule.All)
|
|
if len(rule.Filter) > 0 {
|
|
fmt.Fprintf(w, "\tFilters:\t%s\n", strings.Join(rule.Filter, " "))
|
|
}
|
|
if rule.KeepDuration > 0 {
|
|
fmt.Fprintf(w, "\tKeep Duration:\t%v\n", rule.KeepDuration.String())
|
|
}
|
|
if rule.KeepBytes > 0 {
|
|
fmt.Fprintf(w, "\tKeep Bytes:\t%s\n", units.BytesSize(float64(rule.KeepBytes)))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
w.Flush()
|
|
|
|
return nil
|
|
}
|
|
|
|
func inspectCmd(dockerCli command.Cli, rootOpts *rootOptions) *cobra.Command {
|
|
var options inspectOptions
|
|
|
|
cmd := &cobra.Command{
|
|
Use: "inspect [NAME]",
|
|
Short: "Inspect current builder instance",
|
|
Args: cli.RequiresMaxArgs(1),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
options.builder = rootOpts.builder
|
|
if len(args) > 0 {
|
|
options.builder = args[0]
|
|
}
|
|
return runInspect(dockerCli, options)
|
|
},
|
|
ValidArgsFunction: completion.BuilderNames(dockerCli),
|
|
}
|
|
|
|
flags := cmd.Flags()
|
|
flags.BoolVar(&options.bootstrap, "bootstrap", false, "Ensure builder has booted before inspecting")
|
|
|
|
return cmd
|
|
}
|
|
|
|
func sortedKeys(m map[string]string) []string {
|
|
s := make([]string, len(m))
|
|
i := 0
|
|
for k := range m {
|
|
s[i] = k
|
|
i++
|
|
}
|
|
sort.Strings(s)
|
|
return s
|
|
}
|