常用的清理 Kubernetes 集群资源命令

云计算
长时间运行的集群,常会面临各种资源耗尽的问题,另外磁盘不足时 Kubelet 还会主动清理镜像增加不确定因素,本文提供了一些命令片段用于清理工作。

[[442097]]

长时间运行的集群,常会面临各种资源耗尽的问题,另外磁盘不足时 Kubelet 还会主动清理镜像增加不确定因素,本文提供了一些命令片段用于清理工作。

1. Kubernetes 基础对象清理

  • 清理 Evicted 状态的 Pod
kubectl get pods --all-namespaces -o wide | grep Evicted | awk '{print $1,$2}' | xargs -L1 kubectl delete pod -n 
  • 1.
  • 清理 Error 状态的 Pod
kubectl get pods --all-namespaces -o wide | grep Error | awk '{print $1,$2}' | xargs -L1 kubectl delete pod -n 
  • 1.
  • 清理 Completed 状态的 Pod
kubectl get pods --all-namespaces -o wide | grep Completed | awk '{print $1,$2}' | xargs -L1 kubectl delete pod -n 
  • 1.
  • 清理没有被使用的 PV
kubectl describe -A pvc | grep -E "^Name:.*$|^Namespace:.*$|^Used By:.*$" | grep -B 2 "<none>" | grep -E "^Name:.*$|^Namespace:.*$" | cut -f2 -d: | paste -d " " - - | xargs -n2 bash -c 'kubectl -n ${1} delete pvc ${0}' 
  • 1.
  • 清理没有被绑定的 PVC
kubectl get pvc --all-namespaces | tail -n +2 | grep -v Bound | awk '{print $1,$2}' | xargs -L1 kubectl delete pvc -n 
  • 1.
  • 清理没有被绑定的 PV
kubectl get pv | tail -n +2 | grep -v Bound | awk '{print $1}' | xargs -L1 kubectl delete pv 
  • 1.

2. Linux 清理

  • 查看磁盘全部空间
Filesystem      Size  Used Avail Use% Mounted on 
/dev/sda2       100G   47G   54G  47% / 
  • 1.
  • 2.
  • 查看指定目录占用
du -sh . 
 
24G . 
  • 1.
  • 2.
  • 3.
  • 删除指定前缀的文件夹
cd /nfsdata 
ls | grep archived- |xargs -L1 rm -r 
  • 1.
  • 2.
  • 清理僵尸进程
ps -A -ostat,ppid | grep -e '^[Zz]' | awk '{print }' | xargs kill -HUP > /dev/null 2>&1 
  • 1.

3. Docker 清理

  • 查看磁盘使用情况
docker system df 
 
TYPE                TOTAL               ACTIVE              SIZE                RECLAIMABLE 
Images              361                 23                  178.5GB             173.8GB (97%) 
Containers          29                  9                   6.682GB             6.212GB (92%) 
Local Volumes       4                   0                   3.139MB             3.139MB (100%) 
Build Cache         0                   0                   0B                  0B 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 清理 none 镜像
docker images | grep none | awk '{print $3}' | xargs docker rmi 
  • 1.
  • 清理不再使用的数据卷
docker volume rm $(docker volume ls -q) 
  • 1.

或者

docker volume prune 
  • 1.
  • 清理缓存
docker builder prune 
  • 1.
  • 全面清理

删除关闭的容器、无用的存储卷、无用的网络、dangling 镜像(无 tag 镜像)

docker system prune -f 
  • 1.
  • 清理正则匹配上的镜像

这里清理的是 master-8bcf8d7-20211206-111155163 格式的镜像。

docker images |grep -E "([0-9a-z]*[-]){3,}[0-9]{9}" |awk '{print $3}' | xargs docker rmi 
  • 1.

4. 设置定时

  • 查看定时任务
crontab -l 
  • 1.
  • 设置定时任务
crontab -e  
  • 1.

文本新增定时任务

*/35 */6 * * *  docker images | grep none | awk '{print $3}' | xargs docker rmi 
45 1 * * * docker system prune -f 
  • 1.
  • 2.

这里第一个任务是每隔六个小时的第 35 分钟执行,第二个任务每天的 1 时 45 分执行。

  • 定时任务的格式

设置定时格式: * * * * * shell

 

第一个星号,minute,分钟,值为 0-59 第二个星号,hour,小时,值从 0-23 第三个星号,day,天,值为从 1-31 第四个星号,month,月,值为从 1-12 月,或者简写的英文,比如 Nov、Feb 等 第五个星号,week 周,值为从 0-6 或者简写的英文,Wen、Tur 等,代表周几,其中 0 代表周末

 

责任编辑:武晓燕 来源: 问其
相关推荐

2021-12-20 09:35:14

Kubernetes命令Linux

2020-09-09 07:00:00

Kubernetes集群容器

2022-07-11 09:46:43

Kubernetes开源Linux

2021-11-22 16:21:28

Kubernetes 运维开源

2022-06-14 09:49:10

K8sLinuxKubernetes

2021-06-03 09:00:00

Kubernetes集群容器

2023-11-28 14:04:15

Kubernetes运维

2020-07-31 07:00:00

Kubernetes容器Linux

2020-03-13 08:00:00

.NET对象清理垃圾回收

2021-03-25 16:27:35

Docker磁盘容器

2013-08-19 17:25:18

.Net托管

2023-06-27 17:37:08

Kubernete容器集群

2020-11-23 08:48:00

Kubernetes容器开发

2024-07-25 11:22:23

2015-07-17 10:25:43

kubernetesDocker集群系统

2021-12-24 10:47:49

Kubernetes容器化微服务

2022-03-24 08:04:50

Kubernetes资源限制

2022-01-12 11:55:43

Kubernetes多集群Linux

2022-06-21 08:03:49

RBAC 限制容器

2020-04-02 15:10:57

Kubernetes集群安全
点赞
收藏

51CTO技术栈公众号