in pkg/clusterapi/kubevip.go [31:123]
func kubeVip(address, image string) *corev1.Pod {
return &corev1.Pod{
TypeMeta: metav1.TypeMeta{
APIVersion: corev1.SchemeGroupVersion.String(),
Kind: "Pod",
},
ObjectMeta: metav1.ObjectMeta{
Name: "kube-vip",
Namespace: constants.KubeSystemNamespace,
},
Spec: corev1.PodSpec{
Containers: []corev1.Container{
{
Name: "kube-vip",
Image: image,
Args: []string{"manager"},
Env: []corev1.EnvVar{
{
Name: "vip_arp",
Value: "true",
},
{
Name: "port",
Value: "6443",
},
{
Name: "vip_cidr",
Value: "32",
},
{
Name: "cp_enable",
Value: "true",
},
{
Name: "cp_namespace",
Value: "kube-system",
},
{
Name: "vip_ddns",
Value: "false",
},
{
Name: "vip_leaderelection",
Value: "true",
},
{
Name: "vip_leaseduration",
Value: "15",
},
{
Name: "vip_renewdeadline",
Value: "10",
},
{
Name: "vip_retryperiod",
Value: "2",
},
{
Name: "address",
Value: address,
},
},
ImagePullPolicy: corev1.PullIfNotPresent,
SecurityContext: &corev1.SecurityContext{
Capabilities: &corev1.Capabilities{
Add: []corev1.Capability{
"NET_ADMIN",
"NET_RAW",
},
},
},
VolumeMounts: []corev1.VolumeMount{
{
Name: "kubeconfig",
MountPath: "/etc/kubernetes/admin.conf",
},
},
},
},
HostNetwork: true,
Volumes: []corev1.Volume{
{
Name: "kubeconfig",
VolumeSource: corev1.VolumeSource{
HostPath: &corev1.HostPathVolumeSource{
Path: "/etc/kubernetes/admin.conf",
},
},
},
},
},
}
}