2017-10-29 09:45:21 +00:00
|
|
|
package services
|
|
|
|
|
|
|
|
import (
|
2018-01-09 22:10:56 +00:00
|
|
|
"context"
|
2018-02-13 00:47:56 +00:00
|
|
|
"fmt"
|
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"
|
2018-01-09 22:10:56 +00:00
|
|
|
"github.com/rancher/rke/log"
|
2018-01-31 17:50:55 +00:00
|
|
|
"github.com/rancher/types/apis/management.cattle.io/v3"
|
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-12-19 22:18:27 +00:00
|
|
|
|
2017-12-22 01:01:53 +00:00
|
|
|
KubeAPIPort = 6443
|
2017-12-19 22:18:27 +00:00
|
|
|
SchedulerPort = 10251
|
|
|
|
KubeControllerPort = 10252
|
|
|
|
KubeletPort = 10250
|
|
|
|
KubeproxyPort = 10256
|
2017-10-29 09:45:21 +00:00
|
|
|
)
|
|
|
|
|
2018-02-13 00:47:56 +00:00
|
|
|
func runSidekick(ctx context.Context, host *hosts.Host, prsMap map[string]v3.PrivateRegistry, sidecarProcess v3.Process) error {
|
2018-01-09 22:10:56 +00:00
|
|
|
isRunning, err := docker.IsContainerRunning(ctx, host.DClient, host.Address, SidekickContainerName, true)
|
2017-12-08 23:05:55 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if isRunning {
|
2018-01-09 22:10:56 +00:00
|
|
|
log.Infof(ctx, "[%s] Sidekick container already created on host [%s]", SidekickServiceName, host.Address)
|
2017-12-08 23:05:55 +00:00
|
|
|
return nil
|
|
|
|
}
|
2018-02-13 00:47:56 +00:00
|
|
|
|
|
|
|
imageCfg, hostCfg, _ := getProcessConfig(sidecarProcess)
|
|
|
|
sidecarImage := sidecarProcess.Image
|
|
|
|
if err := docker.UseLocalOrPull(ctx, host.DClient, host.Address, sidecarImage, SidekickServiceName, prsMap); err != nil {
|
2017-12-08 23:05:55 +00:00
|
|
|
return err
|
|
|
|
}
|
2018-01-09 22:10:56 +00:00
|
|
|
if _, err := docker.CreateContiner(ctx, host.DClient, host.Address, SidekickContainerName, imageCfg, hostCfg); err != nil {
|
2017-12-08 23:05:55 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2018-01-09 22:10:56 +00:00
|
|
|
func removeSidekick(ctx context.Context, host *hosts.Host) error {
|
|
|
|
return docker.DoRemoveContainer(ctx, host.DClient, SidekickContainerName, host.Address)
|
2017-12-08 23:05:55 +00:00
|
|
|
}
|
2018-02-13 00:47:56 +00:00
|
|
|
|
|
|
|
func getProcessConfig(process v3.Process) (*container.Config, *container.HostConfig, string) {
|
|
|
|
imageCfg := &container.Config{
|
|
|
|
Entrypoint: process.Command,
|
|
|
|
Cmd: process.Args,
|
|
|
|
Env: process.Env,
|
|
|
|
Image: process.Image,
|
|
|
|
}
|
|
|
|
// var pidMode container.PidMode
|
|
|
|
// pidMode = process.PidMode
|
|
|
|
hostCfg := &container.HostConfig{
|
|
|
|
VolumesFrom: process.VolumesFrom,
|
|
|
|
Binds: process.Binds,
|
|
|
|
NetworkMode: container.NetworkMode(process.NetworkMode),
|
|
|
|
PidMode: container.PidMode(process.PidMode),
|
|
|
|
Privileged: process.Privileged,
|
|
|
|
}
|
|
|
|
if len(process.RestartPolicy) > 0 {
|
|
|
|
hostCfg.RestartPolicy = container.RestartPolicy{Name: process.RestartPolicy}
|
|
|
|
}
|
|
|
|
return imageCfg, hostCfg, process.HealthCheck.URL
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetHealthCheckURL(useTLS bool, port int) string {
|
|
|
|
if useTLS {
|
|
|
|
return fmt.Sprintf("%s%s:%d%s", HTTPSProtoPrefix, HealthzAddress, port, HealthzEndpoint)
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("%s%s:%d%s", HTTPProtoPrefix, HealthzAddress, port, HealthzEndpoint)
|
|
|
|
}
|