
kubectl 工具能够支持三种对象管理方式:
前面我使用了两篇文章讲解了使用配置文件对 Kubernetes 对象进行声明式管理的相关知识点,本篇文章我将带领大家一起学习剩下的两个Kubernetes 对象管理的指令式命令管理和配置文件命令式管理。
使用构建在 kubectl 命令行工具中的指令式命令可以直接快速创建、更新和删除 Kubernetes 对象。本篇文章将解释这些命令的组织方式以及如何使用它们来管理现时对象。
kubectl 工具支持动词驱动的命令,用来创建一些最常见的对象类别。 命令的名称设计使得不熟悉 Kubernetes 对象类型的用户也能做出判断。
kubectl 命令也支持一些对象类型驱动的创建命令。 这些命令可以支持更多的对象类别,并且在其动机上体现得更为明显,不过要求 用户了解它们所要创建的对象的类别。
create <对象类别> [<子类别>] <实例名称>某些对象类别拥有自己的子类别,可以在 create 命令中设置。 例如,Service 对象有 ClusterIP、LoadBalancer 和 NodePort 三种子类别。
下面是一个创建 NodePort 子类别的 Service 的示例:
$ kubectl create service nodeport <服务名称>
在前述示例中,create service nodeport 命令也称作 create service 命令的子命令。 可以使用 -h 标志找到一个子命令所支持的参数和标志。
$ kubectl create service nodeport -h
kubectl 命令也支持一些动词驱动的命令,用来执行一些常见的更新操作。 这些命令的设计是为了让一些不了解 Kubernetes 对象的用户也能执行更新操作, 但不需要了解哪些字段必须设置:
kubectl 命令也支持由对象的某一方面来驱动的更新命令。 设置对象的这一方面可能对不同类别的对象意味着不同的字段:
kubectl 工具支持以下额外的方式用来直接更新现时对象,不过这些操作要求 用户对 Kubernetes 对象的模式定义有很好的了解:
我们可以使用 delete 命令从集群中删除一个对象:
delete <类别>/<名称>可以使用 kubectl delete 来执行指令式命令或者指令式对象配置。不同之处在于传递给命令的参数。要将 kubectl delete 作为指令式命令使用,将要删除的对象作为 参数传递给它。
下面是一个删除名为 nginx 的 Deployment 对象的命令:
$ kubectl delete deployment/nginx
用来打印对象信息的命令有好几个:
有些对象字段在 create 命令中没有对应的标志。在这些场景中, 你可以使用 set 和 create 命令的组合来在对象创建之前设置字段值。 这是通过将 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 -
kubectl create service -o yaml --dry-run=client 创建 Service 的配置,但 将其以 YAML 格式在标准输出上打印而不是发送给 API 服务器。kubectl set selector --local -f - -o yaml 从标准输入读入配置,并将更新后的 配置以 YAML 格式输出到标准输出。kubectl create -f - 使用标准输入上获得的配置创建对象。使用 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
命令 kubectl create service 创建 Service 的配置并将其保存到 /tmp/srv.yaml 文件。
命令 kubectl create --edit 在创建 Service 对象打开其配置文件进行编辑。
使用 kubectl 命令行工具以及用 YAML 或 JSON 编写的对象配置文件来创建、更新和删除 Kubernetes 对象。 本文档说明了如何使用配置文件定义和管理对象。
可以使用 kubectl create -f 从配置文件创建一个对象。
$ kubectl create -f |url>
可以使用 kubectl replace -f 根据配置文件更新活动对象。
$ kubectl replace -f |url>
使用 replace 命令更新对象会删除所有未在配置文件中指定的规范的某些部分。 不应将其规范由集群部分管理的对象使用,比如类型为 LoadBalancer 的服务, 其中 externalIPs 字段独立于配置文件进行管理。 必须将独立管理的字段复制到配置文件中,以防止 replace 删除它们。
你可以使用 kubectl delete -f 删除配置文件中描述的对象。
$ kubectl delete -f |url>
如果配置文件在 metadata 节中设置了 generateName 字段而非 name 字段, 无法使用 kubectl delete -f 来删除该对象。 必须使用其他标志才能删除对象。例如:
$ kubectl delete > >
$ kubectl delete > -l 可以使用 kubectl get -f 查看有关配置文件中描述的对象的信息。
$ kubectl get -f |url> -o yaml
-o yaml 标志指定打印完整的对象配置。 使用 kubectl get -h 查看选项列表。
当完全定义每个对象的配置并将其记录在其配置文件中时,create、 replace 和delete 命令会很好的工作。 但是,当更新一个活动对象,并且更新没有合并到其配置文件中时,下一次执行 replace 时,更新将丢失。 如果控制器,例如 HorizontalPodAutoscaler ,直接对活动对象进行更新,则会发生这种情况。
这有一个例子:
如果需要支持同一对象的多个编写器,则可以使用 kubectl apply 来管理该对象。
假设你具有对象配置文件的 URL。 你可以在创建对象之前使用 kubectl create --edit 对配置进行更改。 这对于指向可以由读者修改的配置文件的教程和任务特别有用。
$ kubectl create -f > --edit
从命令式命令迁移到命令式对象配置涉及几个手动步骤。
将活动对象导出到本地对象配置文件:
$ kubectl get >/> -o yaml > >_>.yaml
从对象配置文件中手动删除状态字段。
对于后续的对象管理,只能使用 replace 。
$ kubectl replace -f >_>.yaml
推荐的方法是定义单个不变的 PodTemplate 标签,该标签仅由控制器选择器使用,而没有其他语义。
标签示例:
selector:
matchLabels:
controller-selector: "apps/v1/deployment/nginx"
template:
metadata:
labels:
controller-selector: "apps/v1/deployment/nginx"
文章写到这里,Kubernetes 对象管理的三种方式已经写完了,如果本篇文章对你有帮助,请支持一下,谢谢。
下一篇我们将一起学习如何使用 kubectl patch 更新 API 对象。