我正在尝试卸载并重新安装 cert-manager 在我们的 Kubernetes 集群上。他们的卸载文档提到:
在继续之前,请确保已删除用户创建的所有 cert-manager 资源。您可以使用以下命令检查是否存在任何现有资源:
$ kubectl get Issuers,ClusterIssuers,Certificates,CertificateRequests,Orders,Challenges --all-namespaces
该命令输出数百种资源,分布在二十几个命名空间中。
我怎样才能有效地删除它们全部而不删除命名空间中的任何其他内容?
该kubectl delete
命令需要在删除某个类型的所有内容时指定命名空间,如下所示:kubectl delete certificates -n example-ns
,所以这里不行。
在指定时循环按名称删除每一个-A
也不起作用,因为我需要指定命名空间:
$ kubectl delete -A order.certmanager.k8s.io/fcfa95477bc0149dbc16c99c54faa82e-cert-1862418815
error: a resource cannot be retrieved by name across all namespaces
这里正确的 cli 魔法是什么?
答案1
您应该删除整个crd
(自定义资源定义),首先列出您的 CRD
kubectl get crd
然后删除 CRD,例如(使用Issuer
作为示例)
kubectl delete crd issuer.<something>.<something>
当 CRD 被删除时,该 CRD 的所有实例(例如 的所有资源kind: Issuer
)也会被删除。