2017-10-29 09:45:21 +00:00
|
|
|
package services
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2017-10-31 13:55:35 +00:00
|
|
|
"net"
|
2017-12-08 23:05:55 +00:00
|
|
|
|
|
|
|
"github.com/docker/docker/api/types/container"
|
|
|
|
"github.com/rancher/rke/docker"
|
|
|
|
"github.com/rancher/rke/hosts"
|
|
|
|
"github.com/sirupsen/logrus"
|
2017-10-29 09:45:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2017-10-31 13:55:35 +00:00
|
|
|
ETCDRole = "etcd"
|
|
|
|
ControlRole = "controlplane"
|
|
|
|
WorkerRole = "worker"
|
|
|
|
|
2017-12-14 21:56:19 +00:00
|
|
|
SidekickServiceName = "sidekick"
|
|
|
|
RBACAuthorizationMode = "rbac"
|
2017-12-13 00:29:24 +00:00
|
|
|
|
2017-10-29 09:45:21 +00:00
|
|
|
KubeAPIContainerName = "kube-api"
|
|
|
|
KubeletContainerName = "kubelet"
|
|
|
|
KubeproxyContainerName = "kube-proxy"
|
|
|
|
KubeControllerContainerName = "kube-controller"
|
|
|
|
SchedulerContainerName = "scheduler"
|
|
|
|
EtcdContainerName = "etcd"
|
2017-11-15 01:12:33 +00:00
|
|
|
NginxProxyContainerName = "nginx-proxy"
|
2017-12-08 23:05:55 +00:00
|
|
|
SidekickContainerName = "service-sidekick"
|
2017-10-29 09:45:21 +00:00
|
|
|
)
|
|
|
|
|
2017-11-07 15:44:17 +00:00
|
|
|
func GetKubernetesServiceIP(serviceClusterRange string) (net.IP, error) {
|
2017-10-31 13:55:35 +00:00
|
|
|
ip, ipnet, err := net.ParseCIDR(serviceClusterRange)
|
2017-10-29 09:45:21 +00:00
|
|
|
if err != nil {
|
2017-11-15 01:12:33 +00:00
|
|
|
return nil, fmt.Errorf("Failed to get kubernetes service IP from Kube API option [service_cluster_ip_range]: %v", err)
|
2017-10-29 09:45:21 +00:00
|
|
|
}
|
2017-10-31 13:55:35 +00:00
|
|
|
ip = ip.Mask(ipnet.Mask)
|
|
|
|
for j := len(ip) - 1; j >= 0; j-- {
|
|
|
|
ip[j]++
|
|
|
|
if ip[j] > 0 {
|
|
|
|
break
|
2017-10-29 09:45:21 +00:00
|
|
|
}
|
|
|
|
}
|
2017-10-31 13:55:35 +00:00
|
|
|
return ip, nil
|
2017-10-29 09:45:21 +00:00
|
|
|
}
|
2017-12-08 23:05:55 +00:00
|
|
|
|
|
|
|
func buildSidekickConfig(sidekickImage string) (*container.Config, *container.HostConfig) {
|
|
|
|
imageCfg := &container.Config{
|
|
|
|
Image: sidekickImage,
|
|
|
|
}
|
|
|
|
hostCfg := &container.HostConfig{
|
|
|
|
NetworkMode: "none",
|
|
|
|
}
|
|
|
|
return imageCfg, hostCfg
|
|
|
|
}
|
|
|
|
|
|
|
|
func runSidekick(host *hosts.Host, sidekickImage string) error {
|
|
|
|
isRunning, err := docker.IsContainerRunning(host.DClient, host.Address, SidekickContainerName, true)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if isRunning {
|
2017-12-13 00:29:24 +00:00
|
|
|
logrus.Infof("[%s] Sidekick container already created on host [%s]", SidekickServiceName, host.Address)
|
2017-12-08 23:05:55 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
imageCfg, hostCfg := buildSidekickConfig(sidekickImage)
|
2017-12-13 00:29:24 +00:00
|
|
|
if err := docker.UseLocalOrPull(host.DClient, host.Address, sidekickImage, SidekickServiceName); err != nil {
|
2017-12-08 23:05:55 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err := docker.CreateContiner(host.DClient, host.Address, SidekickContainerName, imageCfg, hostCfg); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func removeSidekick(host *hosts.Host) error {
|
|
|
|
return docker.DoRemoveContainer(host.DClient, SidekickContainerName, host.Address)
|
|
|
|
}
|