为容器分派扩展资源

特性状态: Kubernetes v1.31 [stable]

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

准备开始

你必须拥有一个 Kubernetes 的集群,且必须配置 kubectl 命令行工具让其与你的集群通信。 建议运行本教程的集群至少有两个节点,且这两个节点不能作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面的 Kubernetes 练习环境之一:

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

在你开始此练习前,请先练习 为节点广播扩展资源。 在那个练习中将配置你的一个节点来广播 dongle 资源。

给 Pod 分派扩展资源

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

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

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

在配置文件中,你可以看到容器请求了 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:

  1. kubectl describe pod extended-resource-demo

输出结果显示 dongle 请求如下:

  1. Limits:
  2. example.com/dongle: 3
  3. Requests:
  4. example.com/dongle: 3

尝试创建第二个 Pod

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

  1. 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. requests:
  11. example.com/dongle: 2
  12. limits:
  13. 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。

  1. Conditions:
  2. Type Status
  3. PodScheduled False
  4. ...
  5. Events:
  6. ...
  7. ... Warning FailedScheduling pod (extended-resource-demo-2) failed to fit in any node
  8. fit failure summary on nodes : Insufficient example.com/dongle (1)

查看 Pod 的状态:

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

输出结果表明 Pod 虽然被创建了,但没有被调度到节点上正常运行。Pod 的状态为 Pending:

  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

接下来

应用开发者参考

集群管理员参考