k3s/pkg/cli/server/server.go

222 lines
7.2 KiB
Go
Raw Normal View History

2019-01-09 11:54:15 -05:00
package server
import (
"context"
"fmt"
net2 "net"
2019-01-09 11:54:15 -05:00
"os"
"path/filepath"
2019-01-22 16:14:58 -05:00
"strings"
2019-01-09 11:54:15 -05:00
systemd "github.com/coreos/go-systemd/daemon"
"github.com/pkg/errors"
2019-01-09 11:54:15 -05:00
"github.com/rancher/k3s/pkg/agent"
"github.com/rancher/k3s/pkg/cli/cmds"
2019-03-08 17:47:44 -05:00
"github.com/rancher/k3s/pkg/datadir"
"github.com/rancher/k3s/pkg/netutil"
2019-03-08 17:47:44 -05:00
"github.com/rancher/k3s/pkg/rootless"
2019-01-09 11:54:15 -05:00
"github.com/rancher/k3s/pkg/server"
"github.com/rancher/k3s/pkg/token"
2019-05-09 18:05:51 -04:00
"github.com/rancher/wrangler/pkg/signals"
2019-01-09 11:54:15 -05:00
"github.com/sirupsen/logrus"
"github.com/urfave/cli"
"k8s.io/apimachinery/pkg/util/net"
2019-05-29 14:53:51 -04:00
"k8s.io/kubernetes/pkg/master"
2019-01-22 16:14:58 -05:00
2019-05-15 19:05:24 -04:00
_ "github.com/go-sql-driver/mysql" // ensure we have mysql
_ "github.com/lib/pq" // ensure we have postgres
_ "github.com/mattn/go-sqlite3" // ensure we have sqlite
2019-01-09 11:54:15 -05:00
)
func Run(app *cli.Context) error {
2019-08-08 01:45:54 -04:00
if err := cmds.InitLogging(); err != nil {
return err
}
2019-01-09 11:54:15 -05:00
return run(app, &cmds.ServerConfig)
}
func run(app *cli.Context, cfg *cmds.Server) error {
var (
err error
)
2019-03-08 17:47:44 -05:00
if !cfg.DisableAgent && os.Getuid() != 0 && !cfg.Rootless {
2019-01-09 11:54:15 -05:00
return fmt.Errorf("must run as root unless --disable-agent is specified")
}
2019-03-08 17:47:44 -05:00
if cfg.Rootless {
dataDir, err := datadir.LocalHome(cfg.DataDir, true)
if err != nil {
return err
}
cfg.DataDir = dataDir
if err := rootless.Rootless(dataDir); err != nil {
return err
}
}
2019-11-14 14:42:42 -05:00
if cfg.Token == "" && cfg.ClusterSecret != "" {
cfg.Token = cfg.ClusterSecret
}
2019-01-09 11:54:15 -05:00
serverConfig := server.Config{}
serverConfig.DisableAgent = cfg.DisableAgent
serverConfig.ControlConfig.Token = cfg.Token
serverConfig.ControlConfig.AgentToken = cfg.AgentToken
serverConfig.ControlConfig.JoinURL = cfg.ServerURL
if cfg.AgentTokenFile != "" {
serverConfig.ControlConfig.AgentToken, err = token.ReadFile(cfg.AgentTokenFile)
if err != nil {
return err
}
}
if cfg.TokenFile != "" {
serverConfig.ControlConfig.Token, err = token.ReadFile(cfg.TokenFile)
if err != nil {
return err
}
}
2019-01-09 11:54:15 -05:00
serverConfig.ControlConfig.DataDir = cfg.DataDir
2019-01-22 16:14:58 -05:00
serverConfig.ControlConfig.KubeConfigOutput = cfg.KubeConfigOutput
serverConfig.ControlConfig.KubeConfigMode = cfg.KubeConfigMode
2019-07-12 12:59:03 -04:00
serverConfig.ControlConfig.NoScheduler = cfg.DisableScheduler
2019-03-08 17:47:44 -05:00
serverConfig.Rootless = cfg.Rootless
serverConfig.ControlConfig.SANs = knownIPs(cfg.TLSSan)
serverConfig.ControlConfig.BindAddress = cfg.BindAddress
2019-05-29 14:53:51 -04:00
serverConfig.ControlConfig.HTTPSPort = cfg.HTTPSPort
serverConfig.ControlConfig.ExtraAPIArgs = cfg.ExtraAPIArgs
serverConfig.ControlConfig.ExtraControllerArgs = cfg.ExtraControllerArgs
serverConfig.ControlConfig.ExtraSchedulerAPIArgs = cfg.ExtraSchedulerArgs
2019-04-12 02:06:35 -04:00
serverConfig.ControlConfig.ClusterDomain = cfg.ClusterDomain
2019-11-15 19:12:27 -05:00
serverConfig.ControlConfig.Datastore.Endpoint = cfg.DatastoreEndpoint
serverConfig.ControlConfig.Datastore.CAFile = cfg.DatastoreCAFile
serverConfig.ControlConfig.Datastore.CertFile = cfg.DatastoreCertFile
serverConfig.ControlConfig.Datastore.KeyFile = cfg.DatastoreKeyFile
2019-05-29 14:53:51 -04:00
serverConfig.ControlConfig.AdvertiseIP = cfg.AdvertiseIP
serverConfig.ControlConfig.AdvertisePort = cfg.AdvertisePort
2019-09-03 19:41:54 -04:00
serverConfig.ControlConfig.FlannelBackend = cfg.FlannelBackend
2019-10-15 17:17:26 -04:00
serverConfig.ControlConfig.ExtraCloudControllerArgs = cfg.ExtraCloudControllerArgs
serverConfig.ControlConfig.DisableCCM = cfg.DisableCCM
2019-10-17 17:46:15 -04:00
serverConfig.ControlConfig.DisableNPC = cfg.DisableNPC
serverConfig.ControlConfig.ClusterInit = cfg.ClusterInit
serverConfig.ControlConfig.ClusterReset = cfg.ClusterReset
2019-05-29 14:53:51 -04:00
2019-07-08 19:02:06 -04:00
if cmds.AgentConfig.FlannelIface != "" && cmds.AgentConfig.NodeIP == "" {
cmds.AgentConfig.NodeIP = netutil.GetIPFromInterface(cmds.AgentConfig.FlannelIface)
}
if serverConfig.ControlConfig.AdvertiseIP == "" && cmds.AgentConfig.NodeExternalIP != "" {
serverConfig.ControlConfig.AdvertiseIP = cmds.AgentConfig.NodeExternalIP
}
2019-05-29 14:53:51 -04:00
if serverConfig.ControlConfig.AdvertiseIP == "" && cmds.AgentConfig.NodeIP != "" {
serverConfig.ControlConfig.AdvertiseIP = cmds.AgentConfig.NodeIP
}
if serverConfig.ControlConfig.AdvertiseIP != "" {
serverConfig.ControlConfig.SANs = append(serverConfig.ControlConfig.SANs, serverConfig.ControlConfig.AdvertiseIP)
2019-05-29 14:53:51 -04:00
}
2019-01-09 11:54:15 -05:00
_, serverConfig.ControlConfig.ClusterIPRange, err = net2.ParseCIDR(cfg.ClusterCIDR)
if err != nil {
return errors.Wrapf(err, "Invalid CIDR %s: %v", cfg.ClusterCIDR, err)
}
2019-03-06 05:37:03 -05:00
_, serverConfig.ControlConfig.ServiceIPRange, err = net2.ParseCIDR(cfg.ServiceCIDR)
if err != nil {
return errors.Wrapf(err, "Invalid CIDR %s: %v", cfg.ServiceCIDR, err)
}
2019-12-11 20:23:55 -05:00
_, apiServerServiceIP, err := master.ServiceIPRange(*serverConfig.ControlConfig.ServiceIPRange)
2019-05-29 14:53:51 -04:00
if err != nil {
return err
}
serverConfig.ControlConfig.SANs = append(serverConfig.ControlConfig.SANs, apiServerServiceIP.String())
2019-05-29 14:53:51 -04:00
// If cluster-dns CLI arg is not set, we set ClusterDNS address to be ServiceCIDR network + 10,
// i.e. when you set service-cidr to 192.168.0.0/16 and don't provide cluster-dns, it will be set to 192.168.0.10
if cfg.ClusterDNS == "" {
serverConfig.ControlConfig.ClusterDNS = make(net2.IP, 4)
copy(serverConfig.ControlConfig.ClusterDNS, serverConfig.ControlConfig.ServiceIPRange.IP.To4())
serverConfig.ControlConfig.ClusterDNS[3] = 10
} else {
serverConfig.ControlConfig.ClusterDNS = net2.ParseIP(cfg.ClusterDNS)
}
2019-09-26 20:18:37 -04:00
if cfg.DefaultLocalStoragePath == "" {
dataDir, err := datadir.LocalHome(cfg.DataDir, false)
if err != nil {
return err
}
serverConfig.ControlConfig.DefaultLocalStoragePath = filepath.Join(dataDir, "/storage")
} else {
serverConfig.ControlConfig.DefaultLocalStoragePath = cfg.DefaultLocalStoragePath
}
noDeploys := make([]string, 0)
2019-01-22 16:14:58 -05:00
for _, noDeploy := range app.StringSlice("no-deploy") {
for _, splitNoDeploy := range strings.Split(noDeploy, ",") {
noDeploys = append(noDeploys, splitNoDeploy)
}
}
for _, noDeploy := range noDeploys {
2019-02-02 00:09:11 -05:00
if noDeploy == "servicelb" {
serverConfig.DisableServiceLB = true
continue
}
2019-01-22 16:14:58 -05:00
serverConfig.ControlConfig.Skips = append(serverConfig.ControlConfig.Skips, noDeploy)
}
2019-01-09 11:54:15 -05:00
logrus.Info("Starting k3s ", app.App.Version)
notifySocket := os.Getenv("NOTIFY_SOCKET")
os.Unsetenv("NOTIFY_SOCKET")
2019-05-09 18:05:51 -04:00
ctx := signals.SetupSignalHandler(context.Background())
if err := server.StartServer(ctx, &serverConfig); err != nil {
2019-01-09 11:54:15 -05:00
return err
}
logrus.Info("k3s is up and running")
if notifySocket != "" {
os.Setenv("NOTIFY_SOCKET", notifySocket)
2019-07-18 09:40:39 -04:00
systemd.SdNotify(true, "READY=1\n")
}
2019-01-09 11:54:15 -05:00
if cfg.DisableAgent {
<-ctx.Done()
return nil
}
ip := serverConfig.ControlConfig.BindAddress
2019-03-30 20:10:23 -04:00
if ip == "" {
2019-08-22 14:56:00 -04:00
ip = "127.0.0.1"
2019-03-30 20:10:23 -04:00
}
url := fmt.Sprintf("https://%s:%d", ip, serverConfig.ControlConfig.HTTPSPort)
token, err := server.FormatToken(serverConfig.ControlConfig.Runtime.AgentToken, serverConfig.ControlConfig.Runtime.ServerCA)
if err != nil {
return err
}
2019-01-09 11:54:15 -05:00
agentConfig := cmds.AgentConfig
agentConfig.Debug = app.GlobalBool("bool")
2019-01-22 16:14:58 -05:00
agentConfig.DataDir = filepath.Dir(serverConfig.ControlConfig.DataDir)
2019-01-09 11:54:15 -05:00
agentConfig.ServerURL = url
agentConfig.Token = token
2019-07-24 03:22:31 -04:00
agentConfig.DisableLoadBalancer = true
agentConfig.Rootless = cfg.Rootless
if agentConfig.Rootless {
// let agent specify Rootless kubelet flags, but not unshare twice
agentConfig.RootlessAlreadyUnshared = true
}
2019-01-09 11:54:15 -05:00
return agent.Run(ctx, agentConfig)
}
2019-01-31 18:57:40 -05:00
2019-03-23 13:34:55 -04:00
func knownIPs(ips []string) []string {
ips = append(ips, "127.0.0.1")
2019-01-31 18:57:40 -05:00
ip, err := net.ChooseHostInterface()
if err == nil {
ips = append(ips, ip.String())
}
return ips
}