本文记录在sed awk命令配合下,给kubectl构建参数,实现对pod的操作。
printf
/**
echo abc def | awk '{printf("111 %s 222 %s", $1, $2)}'
111 abc 222 def
*/
/**
echo abc def | awk '{print("111", $2, "222", $2)}'
111 def 222 def
*/
以下命令加入逗号,方便导出改为csv格式,进行数据统计;
/**
获取所有内存大于2GB的pod
kubectl top pod --all-namesapces | sed 's/Mi//g' | awk '{if (NR>1){print $1","$2","$4}}' | sort | awk -F, '$3>2048{print $1","$2","$3}' | awk -F, '{print("kubectl get pod ", $2, " -n ", $1)}' | /bin/bash
*/
获取所有内存大于2GB的pod,将结果写入到/var/log/deleteAbove2GbPods.log,并逐一删除这些pod
/**
for i in `kubectl top pod --all-namesapces | sed 's/Mi//g' | awk '{if (NR>1){print $1","$2","$4}}' | sort | awk -F, '$3>2048{print $1","$2","$3}'`;
do echo $i >> /var/log/deleteAbove2GbPods.log
echo $i | awk -F, '{print("kubectl delete pod ", $2, " -n ",$1)}' | /bin/bash;
done
*/
以上使用的kubectl delete正常删除,可能会导致脚本卡住或者耗时过长,使用的话可以使用强制删除pod命令,替换上面的命令
/**
kubectl delete pod podName -n NAMESPACE --force --grace-period=0
*/