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。

相关推荐
可观测性用观测云20 小时前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes
哈里谢顿2 天前
Kubernetes Operator核心概念、实现原理和实战开发
云原生
阿里云云原生2 天前
你的 OpenClaw 真的在受控运行吗?
云原生
阿里云云原生2 天前
5 分钟零代码改造,让 Go 应用自动获得全链路可观测能力
云原生·go
Shanyoufusu122 天前
RKE2 单节点集群安装 Rancher+ 私有镜像仓库搭建 完整教程
云原生
阿里云云原生2 天前
Dify 官方上架 Higress 插件,轻松接入 AI 网关访问模型服务
云原生
AI攻城狮2 天前
OpenClaw Session 管理完全指南:Context 压缩、重置与持久化
人工智能·云原生·aigc
蝎子莱莱爱打怪3 天前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
阿里云云原生6 天前
阿里云获评 Agentic AI 开发平台领导者,函数计算 AgentRun 赢下关键分!
云原生
蝎子莱莱爱打怪6 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes