func kubeVip()

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",
						},
					},
				},
			},
		},
	}
}