k8s删除Terminating状态的命名空间

小丫11个月前技术文章620

问题描述

Kubernetes中namespace有两种常见的状态,即Active和Terminating状态,其中Terminating状态一般会比较少见,当对应的命名空间下还存在运行的资源,但该命名空间被删除时才会出现所谓的Terminating状态,这种情况下只要等待Kubernetes本身将命名空间下的资源回收后,该命名空间将会被系统自动删除。

但是在某些情况下,即使命名空间下没有运行的资源,但依然无法删除Terminating状态的命名空间的情况,它会一直卡在Terminating状态下。

问题解决

1、查看命名空间详情

kubectl get ns |grep ingress-nginx-2

2、查看该命名空间下的资源

# 查看集群中可以使用命名空间隔离的资源
kubectl api-resources -o name --verbs=list --namespaced | xargs -n 1 kubectl get --show-kind --ignore-not-found -n ingress-nginx-2

发现ingress-nginx-2命名空间下并无资源占用。

3、尝试对命名空间进行删除

直接删除命名空间ingress-nginx-2

kubectl  delete ns ingress-nginx-2

未能正常删除

4、使用强制删除

kubectl  delete ns ingress-nginx-2 --force --grace-period=0

依然无法删除该命名空间

5、使用原生接口删除

大部分情况下删除不掉资源,需要使用原生接口删除。获取namespace的详情信息

kubectl  get ns ingress-nginx-2  -o json > ingress-nginx-2.json

查看namespace定义的json配置,编辑json文件并删除掉spec部分。

vim ingress-nginx-2.json


如果仍然无法删除命名空间,请查看metadata部分是否存在finalizers字段,如果存在,需要通过如下命令进入命名空间后删除该字段:

kubectl edit ns ingress-nginx-2

使用kubectl代理,执行命令

kubectl proxy --port=8080

使用一下命令进行测试

curl http://localhost:8080/api/

输出类似如下内容

image.png使用http接口进行删除

curl -k -H "Content-Type: application/json" -X PUT --data-binary @xx.json http://127.0.0.1:8080/api/v1/namespaces/命名空间的名字/finalize

再次查看,成功删除


相关文章

clickhouse对接集群hdfs(二)

clickhouse对接集群hdfs(二)

前提:集群中已经部署了hadoop集群和clickhouse集群,clickhouse集群进行对接hdfs1、调整配置文件将集群中的hdfs-site.xml文件同步到ck集群节点的/etc/clic...

NameSpaces状态一直为Terminating

NameSpaces状态一直为Terminating

问题描述删除ingress-nginx后发现ingress-nginx的命名空间一直为销毁中,大致查看了下发现命名空间中已经没有其他资源。该状态已经持续了十几个小时强制删除命名空间```Plain T...

 MySQL 两阶段提交

MySQL 两阶段提交

说明MySQL 开启 Binlog 后,所有的事务都会产生 Binlog Event,这些 Event 也是事务数据的一部分。本篇文章介绍 MySQL 如何保证事务 Binlog Event 和 In...

hiveserver2高可用

hiveserver2高可用

一、安装hiveserver2服务步骤1. 将正常使用的hive目录复制到安装hiveserver2的节点(hd3节点)scp -r /opt/hive hd3:/opt/二、配置hive-site....

sparksql集成ranger权限测试

sparksql集成ranger权限测试

##启动thriftserver cd /opt/dtstack/spark/spark_pkg/sbin ./start-thriftserver.sh \ --master yarn \...

PG的锁(一)

一、表级锁1.1 表级锁模式常见锁模式以及应用场景:ACCESS SHARE :select操作获取该模式锁资源,通常情况下所有只读取不修改表的查询都会获取该模式锁资源ROW SHARE : sele...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。