From 844b90100582293729ff0cc763949e03d1561b0a Mon Sep 17 00:00:00 2001 From: Wang Jinglei Date: Fri, 28 Aug 2020 10:27:56 +0800 Subject: [PATCH] feat: use k8s cluster config when buildx used in k8s cluster Signed-off-by: Wang Jinglei --- commands/util.go | 8 +++++++- driver/manager.go | 28 +++++++++++++++++++++++++--- 2 files changed, 32 insertions(+), 4 deletions(-) diff --git a/commands/util.go b/commands/util.go index 5b9ea9b1..3d739781 100644 --- a/commands/util.go +++ b/commands/util.go @@ -177,7 +177,9 @@ func driversForNodeGroup(ctx context.Context, dockerCli command.Cli, ng *store.N dockerapi.NegotiateAPIVersion(ctx) contextStore := dockerCli.ContextStore() - kcc, err := kubernetes.ConfigFromContext(n.Endpoint, contextStore) + + var kcc driver.KubeClientConfig + kcc, err = kubernetes.ConfigFromContext(n.Endpoint, contextStore) if err != nil { // err is returned if n.Endpoint is non-context name like "unix:///var/run/docker.sock". // try again with name="default". @@ -187,6 +189,10 @@ func driversForNodeGroup(ctx context.Context, dockerCli command.Cli, ng *store.N logrus.Error(err) } } + if kcc == nil { + kcc = driver.KubeClientConfigInCluster{} + } + d, err := driver.GetDriver(ctx, "buildx_buildkit_"+n.Name, f, dockerapi, kcc, n.Flags, n.ConfigFile, n.DriverOpts, contextPathHash) if err != nil { di.Err = err diff --git a/driver/manager.go b/driver/manager.go index 05b13b71..bec3e60e 100644 --- a/driver/manager.go +++ b/driver/manager.go @@ -2,11 +2,14 @@ package driver import ( "context" + "io/ioutil" "sort" + "strings" + + "k8s.io/client-go/rest" dockerclient "github.com/docker/docker/client" "github.com/pkg/errors" - "k8s.io/client-go/tools/clientcmd" ) type Factory interface { @@ -22,11 +25,30 @@ type BuildkitConfig struct { // Rootless bool } +type KubeClientConfig interface { + ClientConfig() (*rest.Config, error) + Namespace() (string, bool, error) +} + +type KubeClientConfigInCluster struct{} + +func (k KubeClientConfigInCluster) ClientConfig() (*rest.Config, error) { + return rest.InClusterConfig() +} + +func (k KubeClientConfigInCluster) Namespace() (string, bool, error) { + namespace, err := ioutil.ReadFile("/var/run/secrets/kubernetes.io/serviceaccount/namespace") + if err != nil { + return "", false, err + } + return strings.TrimSpace(string(namespace)), true, nil +} + type InitConfig struct { // This object needs updates to be generic for different drivers Name string DockerAPI dockerclient.APIClient - KubeClientConfig clientcmd.ClientConfig + KubeClientConfig KubeClientConfig BuildkitFlags []string ConfigFile string DriverOpts map[string]string @@ -76,7 +98,7 @@ func GetFactory(name string, instanceRequired bool) Factory { return nil } -func GetDriver(ctx context.Context, name string, f Factory, api dockerclient.APIClient, kcc clientcmd.ClientConfig, flags []string, config string, do map[string]string, contextPathHash string) (Driver, error) { +func GetDriver(ctx context.Context, name string, f Factory, api dockerclient.APIClient, kcc KubeClientConfig, flags []string, config string, do map[string]string, contextPathHash string) (Driver, error) { ic := InitConfig{ DockerAPI: api, KubeClientConfig: kcc,