使用指令式命令管理 Kubernetes 对象
使用构建在kubectl命令行工具中的指令式命令可以直接快速创建、更新和删除 Kubernetes 对象。本文档解释这些命令的组织方式以及如何使用它们来管理现时对象。
在开始之前
安装kubectl。
你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过Minikube构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:
要检查版本,请输入kubectlversion。
权衡取舍
kubectl工具能够支持三种对象管理方式:
如何创建对象
kubectl工具支持动词驱动的命令,用来创建一些最常见的对象类别。 命令的名称设计使得不熟悉 Kubernetes 对象类型的用户也能做出判断。
kubectl命令也支持一些对象类型驱动的创建命令。 这些命令可以支持更多的对象类别,并且在其动机上体现得更为明显,不过要求 用户了解它们所要创建的对象的类别。
某些对象类别拥有自己的子类别,可以在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命令也支持由对象的某一方面来驱动的更新命令。 设置对象的这一方面可能对不同类别的对象意味着不同的字段:
Note:在Kubernetes1.5版本中,并非所有动词驱动的命令都有对应的方面驱动的命令。
kubectl工具支持以下额外的方式用来直接更新现时对象,不过这些操作要求 用户对 Kubernetes 对象的模式定义有很好的了解:
如何删除对象
你可以使用delete命令从集群中删除一个对象:
你可以使用kubectl delete来执行指令式命令或者指令式对象配置。不同之处在于 传递给命令的参数。要将kubectl delete作为指令式命令使用,将要删除的对象作为 参数传递给它。下面是一个删除名为nginx的 Deployment 对象的命令:
kubectl delete deployment/nginx
如何查看对象
用来打印对象信息的命令有好几个:
使用set命令在创建对象之前修改对象
有些对象字段在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 -使用标准输入上获得的配置创建对象。在创建之前使用–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
命令kubectl create service创建 Service 的配置并将其保存到/tmp/srv.yaml文件。命令kubectl create --edit在创建 Service 对象打开其配置文件进行编辑。