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,可以先尝试用其他处理方式来解决,这也是为了避免数据丢失或损坏。

相关推荐
念恒123061 天前
Docker基础--CGroups资源控制实战(包含部分指令)
运维·docker·容器
万里侯1 天前
户外露营攻略:远离城市喧嚣的完美周末
微服务·容器·k8s
万里侯1 天前
云原生安全最佳实践:守护容器化应用的安全防线
微服务·容器·k8s
万里侯1 天前
云原生存储方案对比:选择适合你的存储策略
微服务·容器·k8s
Benszen1 天前
docker简介
运维·docker·容器
木雷坞1 天前
K8s v1.36 AI 任务启动失败排查:PodGroup、DRA、ImagePullBackOff
人工智能·容器·kubernetes
MAVER1CK1 天前
Docker容器创建好后修改容器配置
运维·docker·容器
音符犹如代码2 天前
Docker 一键部署带有 TimescaleDB 插件的 PostgreSQL
java·运维·数据库·后端·docker·postgresql·容器
YuanDaima20482 天前
Docker 工程化安装与核心命令实战
运维·人工智能·docker·微服务·容器·bash
cgsthtm2 天前
rocky linux 8.10 下的 podman 配置镜像加速
docker·podman·镜像加速·podman-docker·毫秒镜像