使用配置文件命令式管理 Kubernetes 对象

Kubernetes 对象可以使用 kubectl 命令行工具以及用 YAML 或 JSON 编写的对象配置文件来创建、更新和删除。本文档介绍了如何使用配置文件来定义和管理对象。

开始之前

安装 kubectl

您需要拥有一个 Kubernetes 集群,并且 kubectl 命令行工具必须配置为与您的集群通信。建议在至少包含两个节点(不是作为控制平面主机)的集群上运行本教程。如果您还没有集群,可以使用 minikube 创建一个,或者您可以使用以下 Kubernetes Playground 之一

要检查版本,请输入 kubectl version

权衡取舍

kubectl 工具支持三种对象管理类型

  • 命令式命令
  • 命令式对象配置
  • 声明式对象配置

有关每种对象管理类型的优点和缺点的讨论,请参阅 Kubernetes 对象管理

如何创建对象

您可以使用 kubectl create -f 从配置文件中创建一个对象。有关详细信息,请参阅 Kubernetes API 参考

  • kubectl create -f <filename|url>

如何更新对象

您可以使用 kubectl replace -f 根据配置文件更新实时对象。

  • kubectl replace -f <filename|url>

如何删除对象

您可以使用 kubectl delete -f 删除配置文件中描述的对象。

  • kubectl delete -f <filename|url>

如何查看对象

您可以使用 kubectl get -f 查看配置文件中描述的对象的信息。

  • kubectl get -f <filename|url> -o yaml

-o yaml 标志指定打印完整对象配置。使用 kubectl get -h 查看选项列表。

限制

createreplacedelete 命令在每个对象的配置完全定义并记录在其配置文件中时运行良好。但是,当实时对象被更新,并且更新未合并到其配置文件中时,下次执行 replace 时,这些更新将丢失。如果控制器(例如 HorizontalPodAutoscaler)直接对实时对象进行更新,就会发生这种情况。这是一个示例

  1. 您从配置文件中创建一个对象。
  2. 另一个来源通过更改某些字段来更新对象。
  3. 您从配置文件中替换对象。步骤 2 中其他来源所做的更改将丢失。

如果您需要支持对同一对象的多个写入者,可以使用 kubectl apply 来管理该对象。

从 URL 创建和编辑对象而不保存配置

假设您有对象配置文件的 URL。您可以使用 kubectl create --edit 在创建对象之前对配置进行更改。这对于指向读者可以修改的配置文件的教程和任务特别有用。

kubectl create -f <url> --edit

从命令式命令迁移到命令式对象配置

从命令式命令迁移到命令式对象配置涉及多个手动步骤。

  1. 将实时对象导出到本地对象配置文件

    kubectl get <kind>/<name> -o yaml > <kind>_<name>.yaml
    
  2. 从对象配置文件中手动删除状态字段。

  3. 对于后续的对象管理,请独占使用 replace

    kubectl replace -f <kind>_<name>.yaml
    

定义控制器选择器和 PodTemplate 标签

推荐的方法是定义一个单一的、不可变的 PodTemplate 标签,该标签仅由控制器选择器使用,并且没有其他语义含义。

示例标签

selector:
  matchLabels:
      controller-selector: "apps/v1/deployment/nginx"
template:
  metadata:
    labels:
      controller-selector: "apps/v1/deployment/nginx"

下一步

上次修改时间:2022 年 5 月 19 日下午 5:00 PST:在不同的页面中更新了参考,使用了正确的文档标题 (f559518520)