mirror of https://github.com/k3s-io/k3s
225 lines
7.0 KiB
Go
225 lines
7.0 KiB
Go
package cmds
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/rancher/k3s/pkg/daemons/config"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
type Server struct {
|
|
ClusterCIDR string
|
|
ClusterSecret string
|
|
ServiceCIDR string
|
|
ClusterDNS string
|
|
ClusterDomain string
|
|
HTTPSPort int
|
|
HTTPPort int
|
|
DataDir string
|
|
DisableAgent bool
|
|
KubeConfigOutput string
|
|
KubeConfigMode string
|
|
TLSSan cli.StringSlice
|
|
BindAddress string
|
|
ExtraAPIArgs cli.StringSlice
|
|
ExtraSchedulerArgs cli.StringSlice
|
|
ExtraControllerArgs cli.StringSlice
|
|
Rootless bool
|
|
StoreBootstrap bool
|
|
StorageEndpoint string
|
|
StorageCAFile string
|
|
StorageCertFile string
|
|
StorageKeyFile string
|
|
AdvertiseIP string
|
|
AdvertisePort int
|
|
DisableScheduler bool
|
|
FlannelBackend string
|
|
DefaultLocalStoragePath string
|
|
}
|
|
|
|
var ServerConfig Server
|
|
|
|
func NewServerCommand(action func(*cli.Context) error) cli.Command {
|
|
return cli.Command{
|
|
Name: "server",
|
|
Usage: "Run management server",
|
|
UsageText: appName + " server [OPTIONS]",
|
|
Action: action,
|
|
Flags: []cli.Flag{
|
|
VLevel,
|
|
VModule,
|
|
LogFile,
|
|
AlsoLogToStderr,
|
|
cli.StringFlag{
|
|
Name: "bind-address",
|
|
Usage: "k3s bind address (default: localhost)",
|
|
Destination: &ServerConfig.BindAddress,
|
|
},
|
|
cli.IntFlag{
|
|
Name: "https-listen-port",
|
|
Usage: "HTTPS listen port",
|
|
Value: 6443,
|
|
Destination: &ServerConfig.HTTPSPort,
|
|
},
|
|
cli.IntFlag{
|
|
Name: "http-listen-port",
|
|
Usage: "HTTP listen port (for /healthz, HTTPS redirect, and port for TLS terminating LB)",
|
|
Value: 0,
|
|
Destination: &ServerConfig.HTTPPort,
|
|
},
|
|
cli.StringFlag{
|
|
Name: "data-dir,d",
|
|
Usage: "Folder to hold state default /var/lib/rancher/k3s or ${HOME}/.rancher/k3s if not root",
|
|
Destination: &ServerConfig.DataDir,
|
|
},
|
|
cli.BoolFlag{
|
|
Name: "disable-agent",
|
|
Usage: "Do not run a local agent and register a local kubelet",
|
|
Destination: &ServerConfig.DisableAgent,
|
|
},
|
|
cli.StringFlag{
|
|
Name: "cluster-cidr",
|
|
Usage: "Network CIDR to use for pod IPs",
|
|
Destination: &ServerConfig.ClusterCIDR,
|
|
Value: "10.42.0.0/16",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "cluster-secret",
|
|
Usage: "Shared secret used to bootstrap a cluster",
|
|
Destination: &ServerConfig.ClusterSecret,
|
|
EnvVar: "K3S_CLUSTER_SECRET",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "service-cidr",
|
|
Usage: "Network CIDR to use for services IPs",
|
|
Destination: &ServerConfig.ServiceCIDR,
|
|
Value: "10.43.0.0/16",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "cluster-dns",
|
|
Usage: "Cluster IP for coredns service. Should be in your service-cidr range",
|
|
Destination: &ServerConfig.ClusterDNS,
|
|
Value: "",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "cluster-domain",
|
|
Usage: "Cluster Domain",
|
|
Destination: &ServerConfig.ClusterDomain,
|
|
Value: "cluster.local",
|
|
},
|
|
cli.StringSliceFlag{
|
|
Name: "no-deploy",
|
|
Usage: "Do not deploy packaged components (valid items: coredns, servicelb, traefik)",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "write-kubeconfig,o",
|
|
Usage: "Write kubeconfig for admin client to this file",
|
|
Destination: &ServerConfig.KubeConfigOutput,
|
|
EnvVar: "K3S_KUBECONFIG_OUTPUT",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "write-kubeconfig-mode",
|
|
Usage: "Write kubeconfig with this mode",
|
|
Destination: &ServerConfig.KubeConfigMode,
|
|
EnvVar: "K3S_KUBECONFIG_MODE",
|
|
},
|
|
cli.StringSliceFlag{
|
|
Name: "tls-san",
|
|
Usage: "Add additional hostname or IP as a Subject Alternative Name in the TLS cert",
|
|
Value: &ServerConfig.TLSSan,
|
|
},
|
|
cli.StringSliceFlag{
|
|
Name: "kube-apiserver-arg",
|
|
Usage: "Customized flag for kube-apiserver process",
|
|
Value: &ServerConfig.ExtraAPIArgs,
|
|
},
|
|
cli.StringSliceFlag{
|
|
Name: "kube-scheduler-arg",
|
|
Usage: "Customized flag for kube-scheduler process",
|
|
Value: &ServerConfig.ExtraSchedulerArgs,
|
|
},
|
|
cli.StringSliceFlag{
|
|
Name: "kube-controller-arg",
|
|
Usage: "Customized flag for kube-controller-manager process",
|
|
Value: &ServerConfig.ExtraControllerArgs,
|
|
},
|
|
cli.BoolFlag{
|
|
Name: "rootless",
|
|
Usage: "(experimental) Run rootless",
|
|
Destination: &ServerConfig.Rootless,
|
|
},
|
|
cli.BoolFlag{
|
|
Name: "bootstrap-save",
|
|
Usage: "(experimental) Save bootstrap information in the storage endpoint",
|
|
Hidden: true,
|
|
Destination: &ServerConfig.StoreBootstrap,
|
|
},
|
|
cli.StringFlag{
|
|
Name: "storage-endpoint",
|
|
Usage: "Specify etcd, Mysql, Postgres, or Sqlite (default) data source name",
|
|
Destination: &ServerConfig.StorageEndpoint,
|
|
EnvVar: "K3S_STORAGE_ENDPOINT",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "storage-cafile",
|
|
Usage: "SSL Certificate Authority file used to secure storage backend communication",
|
|
Destination: &ServerConfig.StorageCAFile,
|
|
EnvVar: "K3S_STORAGE_CAFILE",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "storage-certfile",
|
|
Usage: "SSL certification file used to secure storage backend communication",
|
|
Destination: &ServerConfig.StorageCertFile,
|
|
EnvVar: "K3S_STORAGE_CERTFILE",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "storage-keyfile",
|
|
Usage: "SSL key file used to secure storage backend communication",
|
|
Destination: &ServerConfig.StorageKeyFile,
|
|
EnvVar: "K3S_STORAGE_KEYFILE",
|
|
},
|
|
cli.StringFlag{
|
|
Name: "advertise-address",
|
|
Usage: "IP address that apiserver uses to advertise to members of the cluster",
|
|
Destination: &ServerConfig.AdvertiseIP,
|
|
},
|
|
cli.IntFlag{
|
|
Name: "advertise-port",
|
|
Usage: "Port that apiserver uses to advertise to members of the cluster",
|
|
Value: 0,
|
|
Destination: &ServerConfig.AdvertisePort,
|
|
},
|
|
cli.BoolFlag{
|
|
Name: "disable-scheduler",
|
|
Usage: "Disable Kubernetes default scheduler",
|
|
Destination: &ServerConfig.DisableScheduler,
|
|
},
|
|
cli.StringFlag{
|
|
Name: "flannel-backend",
|
|
Usage: fmt.Sprintf("(experimental) One of '%s', '%s', '%s', or '%s'", config.FlannelBackendNone, config.FlannelBackendVXLAN, config.FlannelBackendIPSEC, config.FlannelBackendWireguard),
|
|
Destination: &ServerConfig.FlannelBackend,
|
|
Value: config.FlannelBackendVXLAN,
|
|
},
|
|
cli.StringFlag{
|
|
Name: "default-local-storage-path",
|
|
Usage: "Default local storage path for local provisioner storage class",
|
|
Destination: &ServerConfig.DefaultLocalStoragePath,
|
|
},
|
|
NodeIPFlag,
|
|
NodeNameFlag,
|
|
DockerFlag,
|
|
FlannelFlag,
|
|
FlannelIfaceFlag,
|
|
FlannelConfFlag,
|
|
CRIEndpointFlag,
|
|
PauseImageFlag,
|
|
ResolvConfFlag,
|
|
ExtraKubeletArgs,
|
|
ExtraKubeProxyArgs,
|
|
NodeLabels,
|
|
NodeTaints,
|
|
PrivateRegistryFlag,
|
|
},
|
|
}
|
|
}
|