1
0
mirror of https://github.com/rancher/rke.git synced 2025-04-28 11:36:27 +00:00
rke/cmd/remove.go

174 lines
4.2 KiB
Go
Raw Normal View History

package cmd
import (
"bufio"
"context"
"fmt"
"os"
"strings"
"github.com/rancher/rke/cluster"
2018-07-10 19:21:27 +00:00
"github.com/rancher/rke/dind"
"github.com/rancher/rke/hosts"
"github.com/rancher/rke/log"
"github.com/rancher/rke/pki"
2019-09-03 20:01:22 +00:00
v3 "github.com/rancher/types/apis/management.cattle.io/v3"
"github.com/sirupsen/logrus"
"github.com/urfave/cli"
)
func RemoveCommand() cli.Command {
removeFlags := []cli.Flag{
cli.StringFlag{
Name: "config",
Usage: "Specify an alternate cluster YAML file",
Value: pki.ClusterConfig,
EnvVar: "RKE_CONFIG",
},
cli.BoolFlag{
Name: "force",
Usage: "Force removal of the cluster",
},
cli.BoolFlag{
Name: "local",
2018-07-10 19:21:27 +00:00
Usage: "Remove Kubernetes cluster locally",
},
cli.BoolFlag{
Name: "dind",
Usage: "Remove Kubernetes cluster deployed in dind mode",
},
}
2018-05-15 17:35:52 +00:00
removeFlags = append(removeFlags, commonFlags...)
return cli.Command{
Name: "remove",
Usage: "Teardown the cluster and clean cluster nodes",
Action: clusterRemoveFromCli,
Flags: removeFlags,
}
}
func ClusterRemove(
ctx context.Context,
rkeConfig *v3.RancherKubernetesEngineConfig,
dialersOptions hosts.DialersOptions,
flags cluster.ExternalFlags) error {
log.Infof(ctx, "Tearing down Kubernetes cluster")
2019-07-03 19:26:06 +00:00
2019-10-03 01:56:39 +00:00
kubeCluster, err := cluster.InitClusterObject(ctx, rkeConfig, flags, "")
if err != nil {
return err
}
if err := kubeCluster.SetupDialers(ctx, dialersOptions); err != nil {
return err
}
err = kubeCluster.TunnelHosts(ctx, flags)
if err != nil {
return err
}
logrus.Debugf("Starting Cluster removal")
err = kubeCluster.ClusterRemove(ctx)
if err != nil {
return err
}
log.Infof(ctx, "Cluster removed successfully")
return nil
}
func clusterRemoveFromCli(ctx *cli.Context) error {
2019-09-03 20:01:22 +00:00
logrus.Infof("Running RKE version: %v", ctx.App.Version)
2018-07-10 22:35:11 +00:00
if ctx.Bool("local") {
return clusterRemoveLocal(ctx)
}
2018-06-23 12:52:06 +00:00
clusterFile, filePath, err := resolveClusterFile(ctx)
if err != nil {
return fmt.Errorf("Failed to resolve cluster file: %v", err)
}
force := ctx.Bool("force")
if !force {
reader := bufio.NewReader(os.Stdin)
fmt.Printf("Are you sure you want to remove Kubernetes cluster [y/n]: ")
input, err := reader.ReadString('\n')
input = strings.TrimSpace(input)
if err != nil {
return err
}
if input != "y" && input != "Y" {
return nil
}
}
2018-07-10 19:21:27 +00:00
if ctx.Bool("dind") {
return clusterRemoveDind(ctx)
}
2017-12-16 03:38:15 +00:00
rkeConfig, err := cluster.ParseConfig(clusterFile)
if err != nil {
return fmt.Errorf("Failed to parse cluster file: %v", err)
}
rkeConfig, err = setOptionsFromCLI(ctx, rkeConfig)
if err != nil {
return err
}
// setting up the flags
2018-11-12 23:24:59 +00:00
flags := cluster.GetExternalFlags(false, false, false, "", filePath)
return ClusterRemove(context.Background(), rkeConfig, hosts.DialersOptions{}, flags)
2018-01-15 04:36:28 +00:00
}
func clusterRemoveLocal(ctx *cli.Context) error {
var rkeConfig *v3.RancherKubernetesEngineConfig
2018-02-03 01:04:53 +00:00
clusterFile, filePath, err := resolveClusterFile(ctx)
if err != nil {
2018-07-10 22:35:11 +00:00
log.Warnf(context.Background(), "Failed to resolve cluster file, using default cluster instead")
2018-02-03 01:04:53 +00:00
rkeConfig = cluster.GetLocalRKEConfig()
} else {
rkeConfig, err = cluster.ParseConfig(clusterFile)
if err != nil {
return fmt.Errorf("Failed to parse cluster file: %v", err)
}
rkeConfig.Nodes = []v3.RKEConfigNode{*cluster.GetLocalRKENodeConfig()}
}
rkeConfig, err = setOptionsFromCLI(ctx, rkeConfig)
if err != nil {
return err
}
// setting up the flags
2018-11-12 23:24:59 +00:00
flags := cluster.GetExternalFlags(true, false, false, "", filePath)
return ClusterRemove(context.Background(), rkeConfig, hosts.DialersOptions{}, flags)
}
2018-07-10 19:21:27 +00:00
func clusterRemoveDind(ctx *cli.Context) error {
clusterFile, filePath, err := resolveClusterFile(ctx)
if err != nil {
return fmt.Errorf("Failed to resolve cluster file: %v", err)
}
rkeConfig, err := cluster.ParseConfig(clusterFile)
if err != nil {
return fmt.Errorf("Failed to parse cluster file: %v", err)
}
rkeConfig, err = setOptionsFromCLI(ctx, rkeConfig)
if err != nil {
return err
}
for _, node := range rkeConfig.Nodes {
if err = dind.RmoveDindContainer(context.Background(), node.Address); err != nil {
return err
}
}
localKubeConfigPath := pki.GetLocalKubeConfig(filePath, "")
// remove the kube config file
pki.RemoveAdminConfig(context.Background(), localKubeConfigPath)
return err
}