k8s pod 处于Terminating的原因分析和解决处理——筑梦之路

之前整理了一下各种资源长时间无法回收,解决处理的命令行

k8s 各种资源Terminationg状态处理 ------ 筑梦之路_k8s自定义资源修改状态-CSDN博客

这里具体整理下pod长时间处于Terminating状态的相关知识,主要是对前面的补充和完善,作为笔记记录。

背景说明

当我们要删除一个Pod时,Kubernetes会发送删除命令,并开始删除操作。但是,Pod并不会立即被销毁。它先被放置在Terminating状态下,以便它可以完成正在进行的操作。但有时Pod会长时间停留在Terminating状态下,这可能会影响应用程序的正常运行。

常见原因

  1. Pod中有未处理完的请求或资源占用,如长时间运行的进程。
  2. Kubelet或Kubernetes控制平面出现故障,导致无法终止Pod。
  3. Pod中存在未正确关闭的文件描述符或套接字。

解决处理

1. 请求或资源占用

检查确认Pod中是否有未处理完的请求或资源占用,并终止它们。

在Pod中可能存在很多进程或服务,我们可以通过查看Pod的日志、进程列表和资源占用情况,来确定哪些进程或服务没有处理完请求或占用资源。

bash 复制代码
# 查看pod日志

kubectl logs <pod_name>

# 查看pod内进程信息

kubectl exec <pod_name> ps -ef

2. 未正确关闭的文件描述符或套接字

在Pod中可能存在文件描述符或套接字没有正确关闭的情况,这可能会导致Pod不能正常停止或销毁。我们可以通过查看Pod的日志,确认哪些进程或服务存在文件描述符或套接字没有关闭的情况。

这里操作同上,也是查看pod的日志和进程信息,就不再赘述。

3. 强制删除pod

这里就用到了之前那篇里面的命令,需要注意的是强制删除Pod可能会导致数据丢失或数据损坏。因此在进行操作之前,请确保您已经备份了相关数据。

bash 复制代码
kubectl delete pods <pod_name> --grace-period=0 --force

不到万不得已的情况,不建议直接强制删除pod,可以先尝试用其他处理方式来解决,这也是为了避免数据丢失或损坏。

相关推荐
zhaotiannuo_19985 小时前
渗透测试之docker
运维·docker·容器
三不原则6 小时前
故障案例:容器启动失败排查(AI运维场景)——从日志分析到根因定位
运维·人工智能·kubernetes
孤岛悬城6 小时前
54 安装k8s-1.20.11
云原生·容器·kubernetes
ELI_He99910 小时前
Airflow docker 部署
运维·docker·容器
dmonstererer10 小时前
【k8s设置污点/容忍】
java·容器·kubernetes
slient_love11 小时前
docker和docker compose部署安装
docker·容器
钱彬 (Qian Bin)12 小时前
项目实践14—全球证件智能识别系统(切换回SQLite数据库并基于Docker实现离线部署和日常管理)
运维·docker·容器·fastapi·证件识别
岚天start12 小时前
Docker部署NGINX实现服务四层转发方案
服务器·nginx·docker
VermiliEiz13 小时前
二进制文件部署k8s方式(4)
云原生·容器·kubernetes
牛奔13 小时前
docker compose up 命令,默认配置文件自动查找规则
java·spring cloud·docker·容器·eureka