2017-10-29 09:45:21 +00:00
|
|
|
package services
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/rancher/rke/hosts"
|
2017-11-14 18:11:21 +00:00
|
|
|
"github.com/rancher/types/apis/cluster.cattle.io/v1"
|
2017-11-13 21:28:38 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
2017-10-29 09:45:21 +00:00
|
|
|
)
|
|
|
|
|
2017-11-09 19:50:49 +00:00
|
|
|
func RunControlPlane(controlHosts []hosts.Host, etcdHosts []hosts.Host, controlServices v1.RKEConfigServices) error {
|
2017-10-31 13:55:35 +00:00
|
|
|
logrus.Infof("[%s] Building up Controller Plane..", ControlRole)
|
|
|
|
for _, host := range controlHosts {
|
2017-10-29 09:45:21 +00:00
|
|
|
// run kubeapi
|
2017-10-31 13:55:35 +00:00
|
|
|
err := runKubeAPI(host, etcdHosts, controlServices.KubeAPI)
|
2017-10-29 09:45:21 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// run kubecontroller
|
2017-10-31 13:55:35 +00:00
|
|
|
err = runKubeController(host, controlServices.KubeController)
|
2017-10-29 09:45:21 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// run scheduler
|
2017-10-31 13:55:35 +00:00
|
|
|
err = runScheduler(host, controlServices.Scheduler)
|
2017-10-29 09:45:21 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
2017-10-31 13:55:35 +00:00
|
|
|
logrus.Infof("[%s] Successfully started Controller Plane..", ControlRole)
|
2017-10-29 09:45:21 +00:00
|
|
|
return nil
|
|
|
|
}
|
2017-11-15 02:54:26 +00:00
|
|
|
|
|
|
|
func UpgradeControlPlane(controlHosts []hosts.Host, etcdHosts []hosts.Host, controlServices v1.RKEConfigServices) error {
|
|
|
|
logrus.Infof("[%s] Upgrading the Controller Plane..", ControlRole)
|
|
|
|
for _, host := range controlHosts {
|
|
|
|
// upgrade KubeAPI
|
|
|
|
if err := upgradeKubeAPI(host, etcdHosts, controlServices.KubeAPI); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// upgrade KubeController
|
|
|
|
if err := upgradeKubeController(host, controlServices.KubeController); err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// upgrade scheduler
|
|
|
|
err := upgradeScheduler(host, controlServices.Scheduler)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
logrus.Infof("[%s] Successfully upgraded Controller Plane..", ControlRole)
|
|
|
|
return nil
|
|
|
|
}
|