kubectl 批量删除pod,批量删除异常pod

1、阿里云ack集群:test-k8s,有许多异常pod。


image.png

查看dashboard发现很多pod状态是Evicted状态,需要批量删除这些失败了的pod。

方案:

kubectl  get pods | grep Evicted | awk '{print$1}'| xargs kubectl delete pods

kubectl  get pods -n kube-system | grep Evicted | awk '{print$1}'| xargs kubectl delete -n kube-system pods

第一条命令用于删除default namespace下的失败pod,第二条用户删除指定namespace下的失败pod(此处是以kube-system为例)。

解析:

  • 获取所有的pods及其状态。
kubectl  get pods
  • 通过 “|” pipe上一步出参当作下一个操作的入参;
 grep Evicted
  • 执行grep,选出带有Evicted字段的pod
 awk '{print$1}'
  • 通过awk,获取第一列信息,也就是NAME,这一步返回的是一个失败pod名称的列表。
xargs kubectl delete pods
  • 使用xargs指令,循环删除失败pod。
somecommand |xargs command
  • xargs说明
-a file 从文件中读入作为sdtin
-e flag ,注意有的时候可能会是-E,flag必须是一个以空格分隔的标志,当xargs分析到含有flag这个标志的时候就停止。
-p 当每次执行一个argument的时候询问一次用户。
-n num 后面加次数,表示命令在执行的时候一次用的argument的个数,默认是用所有的。
-t 表示先打印命令,然后再执行。
-i 或者是-I,这得看linux支持了,将xargs的每项名称,一般是一行一行赋值给 {},可以用 {} 代替。
-r no-run-if-empty 当xargs的输入为空的时候则停止xargs,不用再去执行了。
-s num 命令行的最大字符数,指的是 xargs 后面那个命令的最大命令行字符数。
-L num 从标准输入一次读取 num 行送给 command 命令。
-l 同 -L。
-d delim 分隔符,默认的xargs分隔符是回车,argument的分隔符是空格,这里修改的是xargs的分隔符。
-x exit的意思,主要是配合-s使用。。
-P 修改最大的进程数,默认是1,为0时候为as many as it can ,这个例子我没有想到,应该平时都用不到的吧。
  • 实际命令案例:
kubectl get pods -n guoji | grep ContainerStatusUnknown | awk '{print$1}' | xargs kubectl delete pods -n guoji
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容