mirror of https://github.com/k3s-io/k3s
63 lines
1.8 KiB
Go
63 lines
1.8 KiB
Go
|
package etcdsnapshot
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"errors"
|
||
|
"os"
|
||
|
"path/filepath"
|
||
|
|
||
|
"github.com/erikdubbelboer/gspt"
|
||
|
"github.com/rancher/k3s/pkg/cli/cmds"
|
||
|
"github.com/rancher/k3s/pkg/cluster"
|
||
|
"github.com/rancher/k3s/pkg/daemons/config"
|
||
|
"github.com/rancher/k3s/pkg/etcd"
|
||
|
"github.com/rancher/k3s/pkg/server"
|
||
|
"github.com/rancher/wrangler/pkg/signals"
|
||
|
"github.com/urfave/cli"
|
||
|
)
|
||
|
|
||
|
func Run(app *cli.Context) error {
|
||
|
if err := cmds.InitLogging(); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return run(app, &cmds.ServerConfig)
|
||
|
}
|
||
|
|
||
|
func run(app *cli.Context, cfg *cmds.Server) error {
|
||
|
gspt.SetProcTitle(os.Args[0])
|
||
|
|
||
|
dataDir, err := server.ResolveDataDir(cfg.DataDir)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
var serverConfig server.Config
|
||
|
serverConfig.DisableAgent = true
|
||
|
serverConfig.ControlConfig.DataDir = dataDir
|
||
|
serverConfig.ControlConfig.EtcdSnapshotName = cfg.EtcdSnapshotName
|
||
|
serverConfig.ControlConfig.EtcdSnapshotDir = cfg.EtcdSnapshotDir
|
||
|
serverConfig.ControlConfig.EtcdSnapshotRetention = 0 // disable retention check
|
||
|
serverConfig.ControlConfig.Runtime = &config.ControlRuntime{}
|
||
|
serverConfig.ControlConfig.Runtime.ETCDServerCA = filepath.Join(dataDir, "tls", "etcd", "server-ca.crt")
|
||
|
serverConfig.ControlConfig.Runtime.ClientETCDCert = filepath.Join(dataDir, "tls", "etcd", "client.crt")
|
||
|
serverConfig.ControlConfig.Runtime.ClientETCDKey = filepath.Join(dataDir, "tls", "etcd", "client.key")
|
||
|
|
||
|
ctx := signals.SetupSignalHandler(context.Background())
|
||
|
|
||
|
initialized, err := etcd.NewETCD().IsInitialized(ctx, &serverConfig.ControlConfig)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
if !initialized {
|
||
|
return errors.New("managed etcd database has not been initialized")
|
||
|
}
|
||
|
|
||
|
cluster := cluster.New(&serverConfig.ControlConfig)
|
||
|
|
||
|
if err := cluster.Bootstrap(ctx); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
return cluster.Snapshot(ctx, &serverConfig.ControlConfig)
|
||
|
}
|