mirror of
https://github.com/rancher/rke.git
synced 2025-06-25 15:01:58 +00:00
47 lines
1.1 KiB
Go
47 lines
1.1 KiB
Go
package cluster
|
|
|
|
import (
|
|
"github.com/rancher/rke/hosts"
|
|
"github.com/rancher/rke/pki"
|
|
"github.com/rancher/rke/services"
|
|
)
|
|
|
|
func (c *Cluster) ClusterRemove() error {
|
|
// Remove Worker Plane
|
|
if err := services.RemoveWorkerPlane(c.WorkerHosts, true); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Remove Contol Plane
|
|
if err := services.RemoveControlPlane(c.ControlPlaneHosts, true); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Remove Etcd Plane
|
|
if err := services.RemoveEtcdPlane(c.EtcdHosts); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Clean up all hosts
|
|
if err := cleanUpHosts(c.ControlPlaneHosts, c.WorkerHosts, c.EtcdHosts, c.SystemImages[AplineImage]); err != nil {
|
|
return err
|
|
}
|
|
|
|
pki.RemoveAdminConfig(c.LocalKubeConfigPath)
|
|
return nil
|
|
}
|
|
|
|
func cleanUpHosts(cpHosts, workerHosts, etcdHosts []*hosts.Host, cleanerImage string) error {
|
|
allHosts := []*hosts.Host{}
|
|
allHosts = append(allHosts, cpHosts...)
|
|
allHosts = append(allHosts, workerHosts...)
|
|
allHosts = append(allHosts, etcdHosts...)
|
|
|
|
for _, host := range allHosts {
|
|
if err := host.CleanUpAll(cleanerImage); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|