mirror of
https://github.com/rancher/rke.git
synced 2025-09-01 15:06:23 +00:00
46 lines
1.2 KiB
Go
46 lines
1.2 KiB
Go
package hosts
|
|
|
|
import (
|
|
"github.com/Sirupsen/logrus"
|
|
"github.com/docker/docker/client"
|
|
"github.com/rancher/rke/k8s"
|
|
"k8s.io/client-go/kubernetes"
|
|
)
|
|
|
|
type Host struct {
|
|
IP string `yaml:"ip"`
|
|
AdvertiseAddress string `yaml:"advertise_address"`
|
|
Role []string `yaml:"role"`
|
|
Hostname string `yaml:"hostname"`
|
|
User string `yaml:"user"`
|
|
DockerSocket string `yaml:"docker_socket"`
|
|
DClient *client.Client
|
|
}
|
|
|
|
func ReconcileWorkers(currentWorkers []Host, newWorkers []Host, kubeClient *kubernetes.Clientset) error {
|
|
for _, currentWorker := range currentWorkers {
|
|
found := false
|
|
for _, newWorker := range newWorkers {
|
|
if currentWorker.Hostname == newWorker.Hostname {
|
|
found = true
|
|
}
|
|
}
|
|
if !found {
|
|
if err := deleteWorkerNode(¤tWorker, kubeClient); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func deleteWorkerNode(workerNode *Host, kubeClient *kubernetes.Clientset) error {
|
|
logrus.Infof("[hosts] Deleting host [%s] from the cluster", workerNode.Hostname)
|
|
err := k8s.DeleteNode(kubeClient, workerNode.Hostname)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
logrus.Infof("[hosts] Successfully deleted host [%s] from the cluster", workerNode.Hostname)
|
|
return nil
|
|
}
|