为容器分派扩展资源

    该功能是“稳定的”,意味着:

    • 版本名是 vX,其中 X 是整数。
    • 该功能将出现在多个后续释出的软件稳定版中。

    本文介绍如何为容器指定扩展资源。

    FEATURE STATE: Kubernetes v1.17 稳定

    该功能是“稳定的”,意味着:

    • 版本名是 vX,其中 X 是整数。
    • 该功能将出现在多个后续释出的软件稳定版中。

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

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

    给 Pod 分派扩展资源

    要请求扩展资源,需要在您的容器清单中包括 resources:requests 字段。 扩展资源可以使用任何完全限定名称,只是不能使用 *.kubernetes.io/。 有效的扩展资源名的格式为 example.com/foo,其中 example.com 应被替换为您的组织的域名,而 foo 则是描述性的资源名称。

    下面是包含一个容器的 Pod 配置文件:

    在配置文件中,您可以看到容器请求了 3 个 dongles。

    创建 Pod:

    1. kubectl apply -f https://k8s.io/examples/pods/resource/extended-resource-pod.yaml

    检查 Pod 是否运行正常:

    1. kubectl get pod extended-resource-demo

    描述 Pod:

    下面是包含一个容器的 Pod 配置文件,容器请求了 2 个 dongles。

    pods/resource/extended-resource-pod-2.yaml
    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: extended-resource-demo-2
    5. spec:
    6. containers:
    7. - name: extended-resource-demo-2-ctr
    8. image: nginx
    9. resources:
    10. example.com/dongle: 2
    11. limits:
    12. example.com/dongle: 2

    Kubernetes 将不能满足 2 个 dongles 的请求,因为第一个 Pod 已经使用了 4 个可用 dongles 中的 3 个。

    尝试创建 Pod:

    1. kubectl apply -f https://k8s.io/examples/pods/resource/extended-resource-pod-2.yaml

    描述 Pod

    1. kubectl describe pod extended-resource-demo-2

    输出结果表明 Pod 不能被调度,因为没有一个节点上存在两个可用的 dongles。

    查看 Pod 的状态:

    1. kubectl get pod extended-resource-demo-2
    1. NAME READY STATUS RESTARTS AGE
    2. extended-resource-demo-2 0/1 Pending 0 6m

    环境清理

    删除本练习中创建的 Pod:

    1. kubectl delete pod extended-resource-demo
    2. kubectl delete pod extended-resource-demo-2

    应用开发者参考