node ip 고정

2020, May 13    

kuberenetes 구성할때 하나의 노드에 이더넷이 두개인 경우, master 3중화를 위해 vip 가 꼭 필요하거나 RR을 위해 L4를 구성하는 경우이 있는데 reboot을 하거나 혹은 kubeadm join 을 하는 경우, 예상치 못한 문제가 발생할 수 있다. 문제는 어딜봐도 문제 확인을 위한 메세지를 찾을 수 없다. 예를 들어 kube-apiserver, cni pod, kube-proxy 로그에서 파악할 수 없다.

문제해결

kube-adm.conf에 node-ip를 추가하면 이더넷이 두개 이상이라 하더라도 kubenetes 클러스터를 위한 ip를 고정할 수 있다.

$ cat /etc/systemd/system/kubelet.service.d/10-kubeadm.conf 
# Note: This dropin only works with kubeadm and kubelet v1.11+
[Service]
Environment="KUBELET_KUBECONFIG_ARGS=--bootstrap-kubeconfig=/etc/kubernetes/bootstrap-kubelet.conf --kubeconfig=/etc/kubernetes/kubelet.conf"
Environment="KUBELET_CONFIG_ARGS=--config=/var/lib/kubelet/config.yaml --node-ip=10.20.200.101"
# This is a file that "kubeadm init" and "kubeadm join" generates at runtime, populating the KUBELET_KUBEADM_ARGS variable dynamically
EnvironmentFile=-/var/lib/kubelet/kubeadm-flags.env
# This is a file that the user can use for overrides of the kubelet args as a last resort. Preferably, the user should use
# the .NodeRegistration.KubeletExtraArgs object in the configuration files instead. KUBELET_EXTRA_ARGS should be sourced from this file.
EnvironmentFile=-/etc/sysconfig/kubelet
ExecStart=
ExecStart=/usr/bin/kubelet $KUBELET_KUBECONFIG_ARGS $KUBELET_CONFIG_ARGS $KUBELET_KUBEADM_ARGS $KUBELET_EXTRA_ARGS $KUBELET_HOSTNAME_ARGS