使用命令式命令管理 Kubernetes 对象
可以立即使用内置于 kubectl
命令行工具的命令式命令直接快速创建、更新和删除 Kubernetes 对象。本文档解释了这些命令的组织方式以及如何使用它们来管理在线对象。
开始之前
安装 kubectl
。
你需要拥有一个 Kubernetes 集群,并且 kubectl 命令行工具已配置为与你的集群通信。建议你在一个至少有两个非控制平面主机的节点上运行本教程。如果你还没有集群,可以使用 minikube 创建一个,或者使用以下 Kubernetes 游乐场之一:
要检查版本,请输入 kubectl version
。
权衡
kubectl
工具支持三种对象管理方式:
- 命令式命令
- 命令式对象配置
- 声明式对象配置
有关每种对象管理方式的优缺点的讨论,请参阅Kubernetes 对象管理。
如何创建对象
kubectl
工具支持用于创建一些最常用对象类型的动词驱动(verb-driven)命令。这些命令的命名方式使得不熟悉 Kubernetes 对象类型的用户也能识别。
run
: 创建一个新的 Pod 来运行一个容器。expose
: 创建一个新的 Service 对象来对 Pod 之间的流量进行负载均衡。autoscale
: 创建一个新的 Autoscaler 对象来自动横向扩缩一个控制器,例如 Deployment。
kubectl
工具还支持由对象类型驱动的创建命令。这些命令支持更多对象类型,并且它们的意图更明确,但要求用户知道他们想要创建的对象类型。
create <对象类型> [<子类型>] <实例名称>
某些对象类型具有子类型,可以在 create
命令中指定。例如,Service 对象有多种子类型,包括 ClusterIP、LoadBalancer 和 NodePort。这是一个创建 NodePort 子类型 Service 的示例:
kubectl create service nodeport <myservicename>
在上面的示例中,create service nodeport
命令被称为 create service
命令的子命令。
你可以使用 -h
标志来查找子命令支持的参数和标志:
kubectl create service nodeport -h
如何更新对象
kubectl
命令支持用于一些常见更新操作的动词驱动(verb-driven)命令。这些命令的命名方式旨在让不熟悉 Kubernetes 对象的用户无需知道必须设置的特定字段即可执行更新:
scale
: 通过更新控制器的副本数,横向扩缩控制器以添加或移除 Pod。annotate
: 从对象添加或移除注解。label
: 从对象添加或移除标签。
kubectl
命令还支持由对象某个方面驱动的更新命令。设置此方面可能会为不同的对象类型设置不同的字段:
set
<字段>
: 设置对象的某个方面。
说明
在 Kubernetes 1.5 版本中,并非每个动词驱动命令都有相关的方面驱动命令。kubectl
工具支持这些直接更新在线对象的附加方式,但它们需要对 Kubernetes 对象模式有更好的理解。
edit
: 通过在编辑器中打开在线对象的原始配置来直接对其进行编辑。patch
: 使用补丁字符串直接修改在线对象的特定字段。有关补丁字符串的更多详细信息,请参阅 API Conventions 中的补丁部分。
如何删除对象
你可以使用 delete
命令从集群中删除对象:
delete <类型>/<名称>
说明
对于命令式命令和命令式对象配置,都可以使用kubectl delete
。区别在于传递给命令的参数。要将 kubectl delete
用作命令式命令,请将要删除的对象作为参数传递。这是一个传递名为 nginx 的 Deployment 对象的示例:kubectl delete deployment/nginx
如何查看对象
有几个命令用于打印关于对象的信息:
get
: 打印关于匹配对象的基本信息。使用get -h
查看选项列表。describe
: 打印关于匹配对象的汇总详细信息。logs
: 打印在 Pod 中运行的容器的标准输出和标准错误。
使用 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 打印到标准输出,而不是发送给 Kubernetes 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
命令在创建对象之前打开配置文件进行编辑。