使用 python 客户端,我编写了一个函数来驱逐节点上的所有 pod。我如何监控/观察所有 pod 是否被完全驱逐?
我正在使用 create_namespaced_pod_eviction 方法驱逐单个节点上的所有 pod。虽然这有效,但它不会等待进程完成后再继续。在继续我的脚本之前,我需要 100% 完成驱逐过程。我如何监控这个过程的状态?与 kubectl 类似,我希望我的函数在返回之前等待每个 pod 驱逐。
# passes list of pods to evict function
def drain_node(self):
print("Draining node", self._node_name)
self.cordon_node()
pods = self._get_pods()
response = []
for pod in pods:
response.append(self._evict_pod(pod))
return response
# calls the eviction api on each pod
def _evict_pod(self, pod, delete_options=None):
name = pod.metadata.name
namespace = pod.metadata.namespace
body = client.V1beta1Eviction(metadata=client.V1ObjectMeta(name=name, namespace=namespace))
response = self._api.create_namespaced_pod_eviction(name, namespace, body)
return response
# gets list of pods to evict
def _get_pods(self):
all_pods = self._api.list_pod_for_all_namespaces(watch=True, field_selector='spec.nodeName=' + self._node_name)
user_pods = [p for p in all_pods.items
if (p.metadata.namespace != 'kube-system')]
return user_pods