使用命令式命令管理 Kubernetes 对象

Kubernetes 对象可以使用内置在 kubectl 命令行工具中的命令直接快速地创建、更新和删除。 本文档解释了这些命令是如何组织的,以及如何使用它们来管理实时对象。

开始之前

安装 kubectl

您需要有一个 Kubernetes 集群,并且必须配置 kubectl 命令行工具以与您的集群通信。 建议在至少有两个不充当控制平面主机的节点的集群上运行本教程。 如果您还没有集群,可以使用 minikube 创建一个集群,或者使用这些 Kubernetes 游乐场中的一个

要检查版本,请输入 kubectl version

权衡

kubectl 工具支持三种对象管理方式

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

有关每种对象管理方式的优缺点的讨论,请参阅 Kubernetes 对象管理

如何创建对象

kubectl 工具支持动词驱动的命令,用于创建一些最常见的对象类型。 命令的命名方式旨在让不熟悉 Kubernetes 对象类型的用户也能识别。

  • run:创建新的 Pod 来运行容器。
  • expose:创建一个新的 Service 对象,以在 Pod 之间进行负载均衡。
  • autoscale:创建一个新的 Autoscaler 对象,以自动水平扩展控制器,例如 Deployment。

kubectl 工具还支持由对象类型驱动的创建命令。 这些命令支持更多对象类型,并且更明确地表达其意图,但要求用户了解他们打算创建的对象类型。

  • create <objecttype> [<subtype>] <instancename>

某些对象类型具有可以在 create 命令中指定的子类型。 例如,Service 对象具有多种子类型,包括 ClusterIP、LoadBalancer 和 NodePort。 以下示例创建具有 NodePort 子类型的 Service

kubectl create service nodeport <myservicename>

在上面的示例中,create service nodeport 命令称为 create service 命令的子命令。

您可以使用 -h 标志来查找子命令支持的参数和标志

kubectl create service nodeport -h

如何更新对象

kubectl 命令支持动词驱动的命令,用于执行一些常见的更新操作。 这些命令的命名方式使不熟悉 Kubernetes 对象的用户能够在不知道必须设置的特定字段的情况下执行更新

  • scale:水平扩展控制器,通过更新控制器的副本计数来添加或删除 Pod。
  • annotate:从对象添加或删除注释。
  • label:从对象添加或删除标签。

kubectl 命令还支持由对象的某个方面驱动的更新命令。 设置此方面可能会为不同的对象类型设置不同的字段

  • set <field>:设置对象的某个方面。

kubectl 工具支持以下其他方式来直接更新实时对象,但是它们需要更好地了解 Kubernetes 对象模式。

  • edit:通过在编辑器中打开实时对象的配置,直接编辑其原始配置。
  • patch:使用补丁字符串直接修改实时对象的特定字段。 有关补丁字符串的更多详细信息,请参阅 API 约定 中的补丁部分。

如何删除对象

您可以使用 delete 命令从集群中删除对象

  • delete <type>/<name>
kubectl delete deployment/nginx

如何查看对象

有几个命令可以打印有关对象的信息

  • get:打印有关匹配对象的基本信息。 使用 get -h 查看选项列表。
  • describe:打印有关匹配对象的聚合详细信息。
  • logs:打印在 Pod 中运行的容器的 stdout 和 stderr。

使用 set 命令在创建之前修改对象

有些对象字段在 create 命令中没有可用的标志。在某些情况下,您可以使用 setcreate 命令的组合,在创建对象之前为字段指定值。这通过将 create 命令的输出管道传输到 set 命令,然后再管道传输回 create 命令来实现。以下是一个示例

kubectl create service clusterip my-svc --clusterip="None" -o yaml --dry-run=client | kubectl set selector --local -f - 'environment=qa' -o yaml | kubectl create -f -
  1. kubectl create service -o yaml --dry-run=client 命令会创建 Service 的配置,但将其作为 YAML 打印到 stdout,而不是发送到 Kubernetes API 服务器。
  2. kubectl set selector --local -f - -o yaml 命令从 stdin 读取配置,并将更新后的配置作为 YAML 写入 stdout。
  3. kubectl create -f - 命令使用通过 stdin 提供的配置创建对象。

使用 --edit 在创建前修改对象

您可以使用 kubectl create --edit 在创建对象之前对其进行任意修改。以下是一个示例

kubectl create service clusterip my-svc --clusterip="None" -o yaml --dry-run=client > /tmp/srv.yaml
kubectl create --edit -f /tmp/srv.yaml
  1. kubectl create service 命令创建 Service 的配置,并将其保存到 /tmp/srv.yaml
  2. kubectl create --edit 命令在创建对象之前打开配置文件进行编辑。

下一步

上次修改时间:2022 年 5 月 19 日下午 5:00(太平洋标准时间):使用文档的正确标题更新了不同页面中的引用 (f559518520)