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。

相关推荐
only_Klein7 小时前
K8S部署ELK(五):集成Kibana实现日志可视化
elk·容器·kubernetes
G皮T9 小时前
【云计算】云主机的亲和性策略(三):云主机 & 宿主机
阿里云·云原生·云计算·虚拟化·云服务器·云主机·弹性计算
❀͜͡傀儡师10 小时前
Docker 安装部署 OceanBase
docker·容器·oceanbase
我能知道个啥13 小时前
一次Kubernetes集群故障处理案例:etcd无法选出Leader导致Kubernetes API-Server启动失败
kubernetes
JuiceFS13 小时前
JuiceFS on Windows: 首个 Beta 版的探索与优化之路
后端·云原生·云计算
David爱编程13 小时前
Cilium 与 Calico 网络安全能力横向评测
云原生·容器·kubernetes
David爱编程13 小时前
Kubernetes中使用Calico实现零信任网络访问控制
云原生·容器·kubernetes
KubeSphere 云原生15 小时前
eBPF 赋能云原生: WizTelemetry 无侵入网络可观测实践
网络·云原生
热心市民梁先生15 小时前
oect刷入arm系统安装docker
运维·docker·容器