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

Kubernetes 对象可以使用内置于 kubectl 命令行工具的命令式命令快速创建、更新和删除。本文档介绍了这些命令的组织方式以及如何使用它们来管理实时对象。

开始之前

安装 kubectl.

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

要检查版本,请输入 kubectl version

权衡取舍

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

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

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

如何创建对象

kubectl 工具支持使用动词驱动的命令来创建一些最常见类型的对象。这些命令的命名方式可以让不熟悉 Kubernetes 对象类型的用户也能够识别。

  • run: 创建一个新的 Pod 来运行一个容器。
  • expose: 创建一个新的服务对象来负载均衡跨 Pod 的流量。
  • autoscale: 创建一个新的自动缩放器对象来自动水平缩放控制器,例如 Deployment。

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

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

某些对象类型具有可以在 create 命令中指定的子类型。例如,服务对象有几种子类型,包括 ClusterIP、LoadBalancer 和 NodePort。以下是一个创建带有 NodePort 子类型的服务的示例

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 中运行的容器的标准输出和标准错误。

使用 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 命令创建服务的配置,但将其作为 YAML 打印到标准输出,而不是将其发送到 Kubernetes API 服务器。
  2. kubectl set selector --local -f - -o yaml 命令从标准输入读取配置,并将更新后的配置作为 YAML 写入标准输出。
  3. kubectl create -f - 命令使用通过标准输入提供的配置创建对象。

使用 --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 命令创建服务的配置并将其保存到 /tmp/srv.yaml
  2. kubectl create --edit 命令在创建对象之前打开配置文件进行编辑。

下一步