2020-04-27 17:09:58 +00:00
|
|
|
// +build !no_embedded_executor
|
|
|
|
|
|
|
|
package executor
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"k8s.io/apiserver/pkg/authentication/authenticator"
|
|
|
|
|
|
|
|
proxy "k8s.io/kubernetes/cmd/kube-proxy/app"
|
|
|
|
kubelet "k8s.io/kubernetes/cmd/kubelet/app"
|
|
|
|
|
2021-05-11 19:50:08 +00:00
|
|
|
"github.com/rancher/k3s/pkg/cli/cmds"
|
|
|
|
daemonconfig "github.com/rancher/k3s/pkg/daemons/config"
|
2020-04-27 17:09:58 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
"k8s.io/kubernetes/cmd/kube-apiserver/app"
|
|
|
|
cmapp "k8s.io/kubernetes/cmd/kube-controller-manager/app"
|
|
|
|
sapp "k8s.io/kubernetes/cmd/kube-scheduler/app"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
executor = Embedded{}
|
|
|
|
}
|
|
|
|
|
|
|
|
type Embedded struct{}
|
|
|
|
|
2021-05-11 19:50:08 +00:00
|
|
|
func (Embedded) Bootstrap(ctx context.Context, nodeConfig *daemonconfig.Node, cfg cmds.Agent) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-04-27 17:09:58 +00:00
|
|
|
func (Embedded) Kubelet(args []string) error {
|
2020-08-05 16:26:36 +00:00
|
|
|
command := kubelet.NewKubeletCommand(context.Background())
|
2020-04-27 17:09:58 +00:00
|
|
|
command.SetArgs(args)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
logrus.Fatalf("kubelet exited: %v", command.Execute())
|
|
|
|
}()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (Embedded) KubeProxy(args []string) error {
|
|
|
|
command := proxy.NewProxyCommand()
|
|
|
|
command.SetArgs(args)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
logrus.Fatalf("kube-proxy exited: %v", command.Execute())
|
|
|
|
}()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-05-05 22:02:16 +00:00
|
|
|
func (Embedded) APIServer(ctx context.Context, etcdReady <-chan struct{}, args []string) (authenticator.Request, http.Handler, error) {
|
|
|
|
<-etcdReady
|
2020-04-27 17:09:58 +00:00
|
|
|
command := app.NewAPIServerCommand(ctx.Done())
|
|
|
|
command.SetArgs(args)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
logrus.Fatalf("apiserver exited: %v", command.Execute())
|
|
|
|
}()
|
|
|
|
|
|
|
|
startupConfig := <-app.StartupConfig
|
|
|
|
return startupConfig.Authenticator, startupConfig.Handler, nil
|
|
|
|
}
|
|
|
|
|
2020-04-28 22:44:05 +00:00
|
|
|
func (Embedded) Scheduler(apiReady <-chan struct{}, args []string) error {
|
2020-04-27 17:09:58 +00:00
|
|
|
command := sapp.NewSchedulerCommand()
|
|
|
|
command.SetArgs(args)
|
|
|
|
|
|
|
|
go func() {
|
2020-04-28 22:44:05 +00:00
|
|
|
<-apiReady
|
2020-04-27 17:09:58 +00:00
|
|
|
logrus.Fatalf("scheduler exited: %v", command.Execute())
|
|
|
|
}()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-04-28 22:44:05 +00:00
|
|
|
func (Embedded) ControllerManager(apiReady <-chan struct{}, args []string) error {
|
2020-04-27 17:09:58 +00:00
|
|
|
command := cmapp.NewControllerManagerCommand()
|
|
|
|
command.SetArgs(args)
|
|
|
|
|
|
|
|
go func() {
|
2020-04-28 22:44:05 +00:00
|
|
|
<-apiReady
|
2020-04-27 17:09:58 +00:00
|
|
|
logrus.Fatalf("controller-manager exited: %v", command.Execute())
|
|
|
|
}()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|