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。

相关推荐
小猿姐2 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生3 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
2601_961875243 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj3 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
程序员老赵3 天前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
正经教主3 天前
【docker基础】 第八周:容器监控与应用更新策略
运维·docker·容器
kiros_wang3 天前
Docker 使用完整指南
运维·docker·容器
正经教主3 天前
【docker基础】第九周:Docker安全与镜像优化
运维·docker·容器
qq_452396233 天前
第十三篇:《K8s 安全基础:RBAC、ServiceAccount、Pod Security》
java·安全·kubernetes
睡不醒男孩0308233 天前
云原生运维实战:高并发架构下的云原生可观测性、韧性降级与自动化干预体系
数据库·kubernetes·高并发·prometheus·devops·sre·缓存调优