1
0
mirror of https://github.com/rancher/rke.git synced 2025-08-12 12:13:25 +00:00

Fix remove performance issues

This commit is contained in:
moelsayed 2018-10-24 01:38:00 +02:00 committed by Alena Prokharchyk
parent b324973081
commit dd4d19a945
4 changed files with 122 additions and 85 deletions

View File

@ -6,7 +6,9 @@ import (
"github.com/rancher/rke/hosts" "github.com/rancher/rke/hosts"
"github.com/rancher/rke/pki" "github.com/rancher/rke/pki"
"github.com/rancher/rke/services" "github.com/rancher/rke/services"
"github.com/rancher/rke/util"
"github.com/rancher/types/apis/management.cattle.io/v3" "github.com/rancher/types/apis/management.cattle.io/v3"
"golang.org/x/sync/errgroup"
) )
func (c *Cluster) ClusterRemove(ctx context.Context) error { func (c *Cluster) ClusterRemove(ctx context.Context) error {
@ -18,15 +20,16 @@ func (c *Cluster) ClusterRemove(ctx context.Context) error {
if err := services.RemoveWorkerPlane(ctx, c.WorkerHosts, true); err != nil { if err := services.RemoveWorkerPlane(ctx, c.WorkerHosts, true); err != nil {
return err return err
} }
// Remove Contol Plane // Remove Contol Plane
if err := services.RemoveControlPlane(ctx, c.ControlPlaneHosts, true); err != nil { if err := services.RemoveControlPlane(ctx, c.ControlPlaneHosts, true); err != nil {
return err return err
} }
// Remove Etcd Plane // Remove Etcd Plane
if err := services.RemoveEtcdPlane(ctx, c.EtcdHosts, true); err != nil { if !externalEtcd {
return err if err := services.RemoveEtcdPlane(ctx, c.EtcdHosts, true); err != nil {
return err
}
} }
// Clean up all hosts // Clean up all hosts
@ -39,15 +42,23 @@ func (c *Cluster) ClusterRemove(ctx context.Context) error {
} }
func cleanUpHosts(ctx context.Context, cpHosts, workerHosts, etcdHosts []*hosts.Host, cleanerImage string, prsMap map[string]v3.PrivateRegistry, externalEtcd bool) error { func cleanUpHosts(ctx context.Context, cpHosts, workerHosts, etcdHosts []*hosts.Host, cleanerImage string, prsMap map[string]v3.PrivateRegistry, externalEtcd bool) error {
allHosts := []*hosts.Host{}
allHosts = append(allHosts, cpHosts...)
allHosts = append(allHosts, workerHosts...)
allHosts = append(allHosts, etcdHosts...)
for _, host := range allHosts { uniqueHosts := hosts.GetUniqueHostList(cpHosts, workerHosts, etcdHosts)
if err := host.CleanUpAll(ctx, cleanerImage, prsMap, externalEtcd); err != nil {
return err var errgrp errgroup.Group
} hostsQueue := util.GetObjectQueue(uniqueHosts)
for w := 0; w < WorkerThreads; w++ {
errgrp.Go(func() error {
var errList []error
for host := range hostsQueue {
runHost := host.(*hosts.Host)
if err := runHost.CleanUpAll(ctx, cleanerImage, prsMap, externalEtcd); err != nil {
errList = append(errList, err)
}
}
return util.ErrList(errList)
})
} }
return nil
return errgrp.Wait()
} }

View File

@ -41,41 +41,43 @@ func RunControlPlane(ctx context.Context, controlHosts []*hosts.Host, localConnD
func RemoveControlPlane(ctx context.Context, controlHosts []*hosts.Host, force bool) error { func RemoveControlPlane(ctx context.Context, controlHosts []*hosts.Host, force bool) error {
log.Infof(ctx, "[%s] Tearing down the Controller Plane..", ControlRole) log.Infof(ctx, "[%s] Tearing down the Controller Plane..", ControlRole)
for _, host := range controlHosts { var errgrp errgroup.Group
// remove KubeAPI hostsQueue := util.GetObjectQueue(controlHosts)
if err := removeKubeAPI(ctx, host); err != nil { for w := 0; w < WorkerThreads; w++ {
return err errgrp.Go(func() error {
} var errList []error
for host := range hostsQueue {
// remove KubeController runHost := host.(*hosts.Host)
if err := removeKubeController(ctx, host); err != nil { if err := removeKubeAPI(ctx, runHost); err != nil {
return nil errList = append(errList, err)
} }
if err := removeKubeController(ctx, runHost); err != nil {
// remove scheduler errList = append(errList, err)
err := removeScheduler(ctx, host) }
if err != nil { if err := removeScheduler(ctx, runHost); err != nil {
return err errList = append(errList, err)
} }
// force is true in remove, false in reconcile
// check if the host already is a worker if force {
if host.IsWorker { if err := removeKubelet(ctx, runHost); err != nil {
log.Infof(ctx, "[%s] Host [%s] is already a worker host, skipping delete kubelet and kubeproxy.", ControlRole, host.Address) errList = append(errList, err)
} else { }
// remove KubeAPI if err := removeKubeproxy(ctx, runHost); err != nil {
if err := removeKubelet(ctx, host); err != nil { errList = append(errList, err)
return err }
if err := removeSidekick(ctx, runHost); err != nil {
errList = append(errList, err)
}
}
} }
// remove KubeController return util.ErrList(errList)
if err := removeKubeproxy(ctx, host); err != nil { })
return nil
}
// remove Sidekick
if err := removeSidekick(ctx, host); err != nil {
return err
}
}
} }
if err := errgrp.Wait(); err != nil {
return err
}
log.Infof(ctx, "[%s] Successfully tore down Controller Plane..", ControlRole) log.Infof(ctx, "[%s] Successfully tore down Controller Plane..", ControlRole)
return nil return nil
} }

View File

@ -15,8 +15,10 @@ import (
"github.com/rancher/rke/hosts" "github.com/rancher/rke/hosts"
"github.com/rancher/rke/log" "github.com/rancher/rke/log"
"github.com/rancher/rke/pki" "github.com/rancher/rke/pki"
"github.com/rancher/rke/util"
"github.com/rancher/types/apis/management.cattle.io/v3" "github.com/rancher/types/apis/management.cattle.io/v3"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
"golang.org/x/sync/errgroup"
) )
const ( const (
@ -72,27 +74,38 @@ func RunEtcdPlane(
func RemoveEtcdPlane(ctx context.Context, etcdHosts []*hosts.Host, force bool) error { func RemoveEtcdPlane(ctx context.Context, etcdHosts []*hosts.Host, force bool) error {
log.Infof(ctx, "[%s] Tearing down etcd plane..", ETCDRole) log.Infof(ctx, "[%s] Tearing down etcd plane..", ETCDRole)
for _, host := range etcdHosts {
err := docker.DoRemoveContainer(ctx, host.DClient, EtcdContainerName, host.Address)
if err != nil {
return err
}
if !host.IsWorker || !host.IsControl || force {
// remove unschedulable kubelet on etcd host
if err := removeKubelet(ctx, host); err != nil {
return err
}
if err := removeKubeproxy(ctx, host); err != nil {
return err
}
if err := removeNginxProxy(ctx, host); err != nil {
return err
}
if err := removeSidekick(ctx, host); err != nil {
return err
}
}
var errgrp errgroup.Group
hostsQueue := util.GetObjectQueue(etcdHosts)
for w := 0; w < WorkerThreads; w++ {
errgrp.Go(func() error {
var errList []error
for host := range hostsQueue {
runHost := host.(*hosts.Host)
if err := docker.DoRemoveContainer(ctx, runHost.DClient, EtcdContainerName, runHost.Address); err != nil {
errList = append(errList, err)
}
if !runHost.IsWorker || !runHost.IsControl || force {
// remove unschedulable kubelet on etcd host
if err := removeKubelet(ctx, runHost); err != nil {
errList = append(errList, err)
}
if err := removeKubeproxy(ctx, runHost); err != nil {
errList = append(errList, err)
}
if err := removeNginxProxy(ctx, runHost); err != nil {
errList = append(errList, err)
}
if err := removeSidekick(ctx, runHost); err != nil {
errList = append(errList, err)
}
}
}
return util.ErrList(errList)
})
}
if err := errgrp.Wait(); err != nil {
return err
} }
log.Infof(ctx, "[%s] Successfully tore down etcd plane..", ETCDRole) log.Infof(ctx, "[%s] Successfully tore down etcd plane..", ETCDRole)
return nil return nil

View File

@ -63,28 +63,39 @@ func doDeployWorkerPlaneHost(ctx context.Context, host *hosts.Host, localConnDia
func RemoveWorkerPlane(ctx context.Context, workerHosts []*hosts.Host, force bool) error { func RemoveWorkerPlane(ctx context.Context, workerHosts []*hosts.Host, force bool) error {
log.Infof(ctx, "[%s] Tearing down Worker Plane..", WorkerRole) log.Infof(ctx, "[%s] Tearing down Worker Plane..", WorkerRole)
for _, host := range workerHosts { var errgrp errgroup.Group
// check if the host already is a controlplane hostsQueue := util.GetObjectQueue(workerHosts)
if host.IsControl && !force { for w := 0; w < WorkerThreads; w++ {
log.Infof(ctx, "[%s] Host [%s] is already a controlplane host, nothing to do.", WorkerRole, host.Address) errgrp.Go(func() error {
return nil var errList []error
} for host := range hostsQueue {
runHost := host.(*hosts.Host)
if err := removeKubelet(ctx, host); err != nil { if runHost.IsControl && !force {
return err log.Infof(ctx, "[%s] Host [%s] is already a controlplane host, nothing to do.", WorkerRole, runHost.Address)
} return nil
if err := removeKubeproxy(ctx, host); err != nil { }
return err if err := removeKubelet(ctx, runHost); err != nil {
} errList = append(errList, err)
if err := removeNginxProxy(ctx, host); err != nil { }
return err if err := removeKubeproxy(ctx, runHost); err != nil {
} errList = append(errList, err)
if err := removeSidekick(ctx, host); err != nil { }
return err if err := removeNginxProxy(ctx, runHost); err != nil {
} errList = append(errList, err)
log.Infof(ctx, "[%s] Successfully tore down Worker Plane..", WorkerRole) }
if err := removeSidekick(ctx, runHost); err != nil {
errList = append(errList, err)
}
}
return util.ErrList(errList)
})
} }
if err := errgrp.Wait(); err != nil {
return err
}
log.Infof(ctx, "[%s] Successfully tore down Worker Plane..", WorkerRole)
return nil return nil
} }