美文网首页
kubectl 批量删除pod,批量删除异常pod

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

作者: 彩色的炮灰 | 来源:发表于2024-12-30 13:39 被阅读0次

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

相关文章

网友评论

      本文标题:kubectl 批量删除pod,批量删除异常pod

      本文链接:https://www.haomeiwen.com/subject/plwaejtx.html