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。
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删除。
上一篇: Linux (CentOS7.5)安装
下一篇: linux怎么删除文件夹