website/content/zh/docs/tasks/configure-pod-container/extended-resource.md

5.3 KiB
Raw Blame History

title content_template weight
为容器分派扩展资源 templates/task 40

{{% capture overview %}}

{{< feature-state state="stable" >}}

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

{{< feature-state state="stable" >}}

{{% /capture %}}

{{% capture prerequisites %}}

{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}}

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

{{% /capture %}}

{{% capture steps %}}

给 Pod 分派扩展资源

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

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

{{< codenew file="pods/resource/extended-resource-pod.yaml" >}}

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

创建 Pod

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

检查 Pod 是否运行正常:

kubectl get pod extended-resource-demo

描述 Pod:

kubectl describe pod extended-resource-demo

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

Limits:
  example.com/dongle: 3
Requests:
  example.com/dongle: 3

尝试创建第二个 Pod

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

{{< codenew file="pods/resource/extended-resource-pod-2.yaml" >}}

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

尝试创建 Pod

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

描述 Pod

kubectl describe pod extended-resource-demo-2

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

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

查看 Pod 的状态:

kubectl get pod extended-resource-demo-2

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

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

环境清理

删除本练习中创建的 Pod

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

{{% /capture %}}

{{% capture whatsnext %}}

应用开发者参考

集群管理员参考

{{% /capture %}}