1
0
mirror of https://github.com/rancher/norman.git synced 2025-08-18 15:27:06 +00:00
norman/pkg/kwrapper/k8s/k3s_linux.go
2019-08-19 14:39:07 -07:00

84 lines
1.7 KiB
Go

package k8s
import (
"context"
"fmt"
"os"
"os/exec"
"path/filepath"
"strings"
"syscall"
"time"
"github.com/rancher/norman/pkg/kwrapper/etcd"
"github.com/sirupsen/logrus"
"k8s.io/client-go/rest"
"k8s.io/client-go/tools/clientcmd"
)
var (
kubeConfig = ".kube/k3s.yaml"
)
func getEmbedded(ctx context.Context) (bool, context.Context, *rest.Config, error) {
var (
err error
)
etcdEndpoints, err := etcd.RunETCD(ctx, "./management-state")
if err != nil {
return false, ctx, nil, err
}
kubeConfig, err := k3sServer(ctx, etcdEndpoints)
if err != nil {
return false, ctx, nil, err
}
os.Setenv("KUBECONFIG", kubeConfig)
restConfig, err := clientcmd.NewNonInteractiveDeferredLoadingClientConfig(
&clientcmd.ClientConfigLoadingRules{ExplicitPath: kubeConfig}, &clientcmd.ConfigOverrides{}).ClientConfig()
return true, ctx, restConfig, err
}
func k3sServer(ctx context.Context, endpoints []string) (string, error) {
cmd := exec.Command("k3s", "server",
"--no-deploy=traefik",
"--no-deploy=coredns",
"--no-deploy=servicelb",
"--disable-agent",
fmt.Sprintf("--storage-endpoint=%s", strings.Join(endpoints, ",")),
"--storage-backend=etcd3")
cmd.SysProcAttr = &syscall.SysProcAttr{
Pdeathsig: syscall.SIGKILL,
}
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
go func() {
err := cmd.Run()
logrus.Fatalf("k3s exited with: %v", err)
}()
home, err := os.UserHomeDir()
if err != nil {
return "", err
}
kubeConfig := filepath.Join(home, kubeConfig)
for {
if _, err := os.Stat(kubeConfig); err == nil {
return kubeConfig, nil
}
logrus.Infof("Waiting for k3s to start")
select {
case <-ctx.Done():
return "", fmt.Errorf("startup interrupted")
case <-time.After(time.Second):
}
}
}