欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

kubernetes 批量删除失败pod

程序员文章站 2022-03-12 10:39:30
...

查看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为例)。

解析:

kubectl  get pods

获取所有的pods及其状态。

| grep Evicted

通过 “|” pipe上一步出参当作下一个操作的入参;

执行grep,选出带有Evicted字段的pod。

| awk '{print$1}'

通过awk,获取第一列信息,也就是NAME,这一步返回的是一个失败pod名称的列表。

| xargs kubectl delete pods

使用xargs指令,循环删除失败pod。

 

xargs说明

somecommand |xargs command
-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 ,这个例子我没有想到,应该平时都用不到的吧。

somecommand会输出一段内容,xargs针对输出,配合参数,会做相应处理,如果没有参数,默认每次用一行数据当作command的参数,例如kubectl get pod | grep Evicted返回的是

。。。。。。。
。。。。。。
。。。。。。。
。。。。。。。。
。。。。。

这样的数据,每一行就是一个pod名称,不加任何参数,就是command  arg1 arg2 ...达到批量删除的目的,前提是命令支持这种形式:kubectl delete pods pod1 pod2 pod3 ... podn 

总结:

也可以通过修改Evicted,来选取其它类型的pod删除。