k8s强制删除状态为 Terminating的Namespace

在 Kubernetes 中,当一个 Namespace 的状态为 Terminating 且长时间无法删除时,通常是因为某些资源未被正确清理。以下是强制删除 Namespace 的步骤:

1. 检查 Namespace 状态

首先,确认 Namespace 的状态:

bash 复制代码
kubectl get ns <namespace-name>

如果状态为 Terminating,继续下一步。

2. 导出 Namespace 的 JSON 文件

导出 Namespace 的 JSON 文件以便编辑:

bash 复制代码
kubectl get ns <namespace-name> -o json > ns.json

3. 编辑 JSON 文件

移除 finalizers 字段,删除下面5行:

bash 复制代码
{
  "spec": {
    "finalizers": ["kubernetes"]
  }
}

4. 使用 curl 强制删除 Namespace

使用 kubectl proxy ·启动 API 代理:

bash 复制代码
kubectl proxy --port=8081

在另一个终端中,使用 curl 强制删除:

bash 复制代码
curl -X PUT --data-binary @ns.json http://localhost:8081/api/v1/namespaces/<namespace-name>/finalize -H "Content-Type: application/json"

5. 验证删除

确认 Namespace 是否已删除:

bash 复制代码
kubectl get ns <namespace-name>

注意事项

风险:强制删除可能导致资源残留,需手动清理。

影响:确保 Namespace 中的资源不再需要。

通过这些步骤,你可以强制删除状态为 Terminating 的 Namespace。

相关推荐
藥瓿亭1 小时前
K8S认证|CKS题库+答案| 9. 网络策略 NetworkPolicy
linux·运维·docker·云原生·容器·kubernetes·cks
955.1 小时前
k8s从入门到放弃之Pod的容器探针检测
云原生·容器·kubernetes
yunken283 小时前
docker容器保存为不依赖基础镜像的独立镜像方法
java·docker·容器
langmeng1103 小时前
使用docker在3台服务器上搭建基于版本redis 6.x的一主两从模式
运维·redis·docker·容器·集群
leblancAndSherry4 小时前
Gitlab + Jenkins 实现 CICD
linux·运维·docker·kubernetes·gitlab·jenkins
脑瓜嗡8 小时前
Docker部署SpringBoot项目
spring boot·docker·容器
容器魔方9 小时前
KubeCon China 2025 | 与KubeEdge畅聊毕业经验与创新未来
云原生·容器·云计算
代码小学僧10 小时前
通俗易懂:给前端开发者的 Docker 入门指南
前端·docker·容器
运维潇哥11 小时前
k8s业务程序联调工具-KtConnect
云原生·容器·kubernetes
欧先生^_^11 小时前
让 Kubernetes (K8s) 集群 使用 GPU
云原生·容器·kubernetes