mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 10:03:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			171 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			171 lines
		
	
	
		
			4.3 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/spf13/cobra"
 | 
						|
)
 | 
						|
 | 
						|
type inspectOptions struct {
 | 
						|
	bootstrap bool
 | 
						|
	builder   string
 | 
						|
}
 | 
						|
 | 
						|
func runInspect(ctx context.Context, dockerCli command.Cli, in inspectOptions) error {
 | 
						|
	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, builder.WithData())
 | 
						|
	if in.bootstrap {
 | 
						|
		var ok bool
 | 
						|
		ok, err = b.Boot(ctx)
 | 
						|
		if err != nil {
 | 
						|
			return err
 | 
						|
		}
 | 
						|
		if ok {
 | 
						|
			nodes, err = b.LoadNodes(timeoutCtx, builder.WithData())
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	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.BuildkitdFlags) > 0 {
 | 
						|
					fmt.Fprintf(w, "BuildKit daemon flags:\t%s\n", strings.Join(n.BuildkitdFlags, " "))
 | 
						|
				}
 | 
						|
				if nodes[i].Version != "" {
 | 
						|
					fmt.Fprintf(w, "BuildKit version:\t%s\n", nodes[i].Version)
 | 
						|
				}
 | 
						|
				platforms := platformutil.FormatInGroups(n.Node.Platforms, n.Platforms)
 | 
						|
				if len(platforms) > 0 {
 | 
						|
					fmt.Fprintf(w, "Platforms:\t%s\n", strings.Join(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(cmd.Context(), 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
 | 
						|
}
 |