当前位置: 首页 > news >正文

使用 YAML 文件,如何优雅地删除 k8s 资源?


在 Kubernetes 中,删除资源是日常运维中不可避免的操作。如果你习惯了使用 kubectl createkubectl apply 来创建和更新资源,那么你可能也会想知道如何用同样基于文件的方式来删除它们。

虽然你总是可以用 kubectl delete deployment <name> 这种方式来删除,但基于文件的删除方法能更好地保持声明式管理的原则,特别是在 GitOps 实践中,它能确保集群的状态与你的代码仓库保持一致。

本文将介绍两种主流的、基于文件来删除 Kubernetes 资源的方法。

方法一:最直接的方式 —— kubectl delete -f

这是最常用、最简单、也最安全的方式。它的工作原理非常直接:读取你指定的 YAML 文件,然后删除文件中定义的所有资源。

如果你有一个名为 my-app.yaml 的文件,其中定义了一个 Deployment 和一个 Service

# my-app.yaml
apiVersion: apps/v1
kind: Deployment
metadata:name: my-app-deployment
spec:# ...---
apiVersion: v1
kind: Service
metadata:name: my-app-service
spec:# ...

要删除这两个资源,你只需运行一个命令:

kubectl delete -f my-app.yaml

优点:

  • 安全:你明确知道自己要删除哪些资源,因为它完全依赖于你指定的文件。
  • 简单:命令清晰,易于记忆和使用。
  • 高效:可以一次性删除文件中定义的所有资源。

方法二:最灵活的方式 —— kubectl apply --prune

这是一个更高级、更强大的命令,它不只是简单地删除,而是用于同步集群状态与本地配置文件

--prune(裁剪)标志的作用是:它会删除那些在你的本地文件中不存在,但在集群中存在在你的管理范围之内的资源。

这个方法通常用于以下场景:你将所有资源定义都放在一个目录里,当你想删除某个资源时,你只需从这个目录中移除对应的 YAML 文件,然后运行 apply --prune 命令。

命令格式:

kubectl apply --prune -f <file_or_directory> -l <selector_label>

需要注意的关键点:

  • --prune 必须与 -f(文件/目录)和 -l(标签选择器)一起使用。
  • -l 标签选择器至关重要! 它定义了 kubectl 应该管理的资源“边界”。没有这个边界,--prune 可能会误删整个命名空间中的所有资源。

一个简单的例子:

假设你的所有应用资源都带有一个 app=my-app 的标签。

  1. 最初,你的文件目录中有 deployment.yamlservice.yaml,都带有 app=my-app 标签。你使用 kubectl apply -f . 部署了它们。
  2. 现在,你决定不再需要 service.yaml。你从目录中删除了这个文件。
  3. 为了让集群状态与你的目录同步,你运行:
kubectl apply --prune -f . -l app=my-app

kubectl 会比较集群状态和你的文件目录:

  • 它发现 deployment 在文件中,所以会保留它。
  • 它发现 service 不在文件中,但它带有 app=my-app 标签,所以 kubectl 会自动将其删除

总结与选择

特性kubectl delete -fkubectl apply --prune
工作原理直接删除文件中定义的资源比较文件与集群状态,移除多余资源
主要用途手动或脚本化地删除特定资源保持集群与 Git 仓库的完全同步
风险低,你明确指定了要删除什么较高,如果标签选择器不当,可能误删

对于日常的、简单的删除操作,kubectl delete -f 是最安全和最推荐的选择。如果你正在实践 GitOps,并希望通过提交和删除 Git 仓库中的文件来自动化集群状态的变更,那么 kubectl apply --prune 将是你的强大工具。

http://www.xdnf.cn/news/1345501.html

相关文章:

  • 高并发用户数峰值对系统架构设计有哪些影响?
  • .java->.class->java 虚拟机中运行
  • 设计模式:抽象工厂模式
  • 实验二 Cisco IOS Site-to-Site Pre-share Key
  • 异质结3.0时代的降本提效革命:捷造科技设备技术创新与产业拐点分析
  • 高级SQL优化 | 告别 Hive 中 GROUP BY 的大 KEY 数据倾斜!PawSQL 自适应优化算法详解
  • Logstash——输出(Output)
  • 大视协作码垛机:颠覆传统制造,开启智能工厂新纪元
  • 【CV】OpenCV①——图形处理简介
  • 2025年视频大模型汇总、各自优势及视频大模型竞争焦点
  • 掌握设计模式--命令模式
  • WebRTC 结合云手机:释放实时通信与虚拟手机的强大协同效能
  • elasticsearch的使用
  • C#_高性能内存处理:Span<T>, Memory<T>, ArrayPool
  • vue vxe-gantt 甘特图自定义任务条样式模板 table 自定义插槽模板
  • Vue2 响应式系统设计原理与实现
  • 【Java并发编程】Java多线程深度解析:状态、通信与停止线程的全面指南
  • 多态(polymorphism)
  • celery
  • 学习python第12天
  • 基于Python的伊人酒店管理系统 Python+Django+Vue.js
  • 探索Thompson Shell:Unix初代Shell的智慧
  • Linux之Ubuntu入门:Vmware中虚拟机中的Ubuntu中的shell命令-常用命令
  • 解决 PyTorch 导入错误:undefined symbol: iJIT_NotifyEvent
  • MTK Linux DRM分析(十一)- MTK KMS Panel显示屏驱动
  • 使用html+css+javascript练习项目布局--创建导航栏
  • Linux驱动开发笔记(六)——pinctrl GPIO
  • MTK Linux DRM分析(十三)- Mediatek KMS实现mtk_drm_drv.c(Part.1)
  • chapter07_初始化和销毁方法
  • 【连接器专题】连接器接触界面的理解