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。

相关推荐
信徒_40 分钟前
Kafka 在 k8s 中的消费者实例
分布式·kafka·kubernetes
从零开始学习人工智能3 小时前
Docker 镜像导出与导入:export/import vs save/load
运维·docker·容器
基哥的奋斗历程5 小时前
Kubernetes 存储 Downward API
云原生·容器·kubernetes
程序边界9 小时前
AIGC时代Kubernetes企业级云原生运维实战:智能重构与深度实践指南
云原生·kubernetes·aigc
dessler12 小时前
Kubernetes(k8s)-Reloader介绍&使用
linux·运维·kubernetes
weixin_4258782313 小时前
k8s 自动伸缩的场景与工作原理
java·容器·kubernetes
lzz的编码时刻13 小时前
K8s私有仓库拉取镜像报错解决:x509 certificate signed by unknown authority
云原生·容器·kubernetes
码哝小鱼13 小时前
docker stack常用命令
docker·容器·eureka
NorthCastle16 小时前
Centos7 上 卸载 docker
运维·docker·容器
{⌐■_■}16 小时前
【Kubernetes】RBAC(基于角色的访问控制)如何设置?如何管理 Kubernetes 的权限?
云原生·容器·kubernetes