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

    安装。

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    要获知版本信息,请输入 kubectl version.

    权衡取舍

    kubectl 工具能够支持三种对象管理方式:

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

    关于每种对象管理的优缺点的讨论,可参见 Kubernetes 对象管理

    如何创建对象

    kubectl 工具支持动词驱动的命令,用来创建一些最常见的对象类别。 命令的名称设计使得不熟悉 Kubernetes 对象类型的用户也能做出判断。

    • run:创建一个新的 Pod 来运行一个容器。
    • expose:创建一个新的 Service 对象为若干 Pod 提供流量负载均衡。
    • autoscale:创建一个新的 Autoscaler 对象来自动对某控制器(例如:Deployment) 执行水平扩缩。
    • create <对象类别> [<子类别>] <实例名称>

    某些对象类别拥有自己的子类别,可以在 create 命令中设置。 例如,Service 对象有 ClusterIP、LoadBalancer 和 NodePort 三种子类别。 下面是一个创建 NodePort 子类别的 Service 的示例:

    在前述示例中,create service nodeport 命令也称作 create service 命令的子命令。 可以使用 -h 标志找到一个子命令所支持的参数和标志。

    kubectl 命令也支持一些动词驱动的命令,用来执行一些常见的更新操作。 这些命令的设计是为了让一些不了解 Kubernetes 对象的用户也能执行更新操作, 但不需要了解哪些字段必须设置:

    • :对某控制器进行水平扩缩以便通过更新控制器的副本个数来添加或删除 Pod。
    • annotate:为对象添加或删除注解。
    • label:为对象添加或删除标签。

    kubectl 命令也支持由对象的某一方面来驱动的更新命令。 设置对象的这一方面可能对不同类别的对象意味着不同的字段:

    • set <字段>:设置对象的某一方面。

    说明:

    在 Kubernetes 1.5 版本中,并非所有动词驱动的命令都有对应的方面驱动的命令。

    • edit:通过在编辑器中打开活跃对象的配置,直接编辑其原始配置。

    如何删除对象

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

    • delete <类别>/<名称>

    说明:

    你可以使用 kubectl delete 来执行指令式命令或者指令式对象配置。不同之处在于传递给命令的参数。 要将 kubectl delete 作为指令式命令使用,将要删除的对象作为参数传递给它。 下面是一个删除名为 nginx 的 Deployment 对象的命令:

    如何查看对象

    用来打印对象信息的命令有好几个:

    • get:打印匹配到的对象的基本信息。使用 get -h 可以查看选项列表。
    • describe:打印匹配到的对象的详细信息的汇集版本。
    • :打印 Pod 中运行的容器的 stdout 和 stderr 输出。

    有些对象字段在 create 命令中没有对应的标志。 在这些场景中,你可以使用 setcreate 命令的组合来在对象创建之前设置字段值。 这是通过将 create 命令的输出用管道方式传递给 set 命令来实现的,最后执行 create 命令来创建对象。 下面是一个例子:

    1. 命令 kubectl create service -o yaml --dry-run=client 创建 Service 的配置, 但将其以 YAML 格式在标准输出上打印而不是发送给 API 服务器。
    2. 命令 kubectl set selector --local -f - -o yaml 从标准输入读入配置, 并将更新后的配置以 YAML 格式输出到标准输出。
    3. 命令 kubectl create -f - 使用标准输入上获得的配置创建对象。

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

    你可以用 kubectl create --edit 来在对象被创建之前执行任意的变更。 下面是一个例子:

    1. 命令 kubectl create service 创建 Service 的配置并将其保存到 /tmp/srv.yaml 文件。
    2. 命令 kubectl create --edit 在创建 Service 对象打开其配置文件进行编辑。

    接下来