mirror of
https://github.com/rancher/norman.git
synced 2025-08-20 08:13:00 +00:00
84 lines
1.7 KiB
Go
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",
|
||
|
"--disable-agent",
|
||
|
"--disable-scheduler",
|
||
|
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):
|
||
|
}
|
||
|
}
|
||
|
}
|