kubernetes 批量删除失败pod

查看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删除。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值