Edit This Page

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

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

权衡

kubectl 工具支持三种方式进行对象的管理:

参见Kubernetes对象管理 讨论各种对象管理方式的优缺点.

如何创建对象

kubectl 工具支持用于创建一些最常用的对象类型的动词驱动命令,这些命令的命名让不熟悉Kubernetes 对象的用户也可以见名知义。

kubectl 工具也支持由对象类型驱动的创建命令。 这些命令支持更多的对象类型,并且对其意图更为明确,但要求用户知道他们打算创建的对象的类型。

某些对象类型具有您可以在“create”命令中指定的子类型。例如,Service对象有ClusterIP,LoadBalancer和NodePort等几种子类型。以下是使用子类型NodePort创建一个服务的示例:

kubectl create service nodeport <myservicename>

在前面的例子中, create service nodeport命令叫做 create service命令的子命令.

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

kubectl create service nodeport -h

如何更新对象

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

kubectl命令还支持由对象的一个​​切面驱动的更新命令.设置此切面可能会为不同的对象类型设置不同的字段:

: 在 Kubernetes 版本 1.5 中,并不是每个动词驱动的命令都有一个相关的切面驱动的命令。

kubectl 工具支持直接更新活动对象的其他方法,然而,它们需要更好的了解 Kubernetes 对象模式。

有关补丁字符串的更多详细信息,请参阅补丁部分 API 公约

如何删除对象

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

注意: 您可以对命令式命令和命令式对象配置都使用 kubectl delete 方法。两者的差异在于传递的命令参数不同。要将 kubectl delete 作为命令式命令使用,需将要删除的对象作为参数传递。以下是传递名为 nginx 的 Deployment 对象的示例:

kubectl delete deployment/nginx

如何查看对象

有几个命令用于打印有关对象的信息:

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

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

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

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

您可以使用 kubectl create --edit 命令在对象创建之前,对对象进行任意更改。以下是一个例子:

kubectl create service clusterip my-svc -o yaml --dry-run > /tmp/srv.yaml
kubectl create --edit -f /tmp/srv.yaml
  1. 使用create service 创建服务的配置并将其保存到 /tmp/srv.yaml
  2. 使用create --edit 在创建对象之前打开配置文件进行编辑。

What's next