向容器分配扩展资源

功能状态: Kubernetes v1.31 [稳定]

此页面展示如何将扩展资源分配给容器。

开始之前

您需要有一个 Kubernetes 集群,并且 kubectl 命令行工具必须配置为与您的集群通信。建议在至少有两个节点(不充当控制平面主机)的集群上运行本教程。如果您还没有集群,您可以使用 minikube 创建一个,或者您可以使用以下 Kubernetes 游乐场之一

要检查版本,请输入 kubectl version

在进行此练习之前,请完成 为节点宣传扩展资源 中的练习。这将配置您的一个节点以宣传 dongle 资源。

将扩展资源分配给 Pod

要请求扩展资源,请在容器清单中包含 resources:requests 字段。扩展资源使用任何不在 *.kubernetes.io/ 之外的域进行完全限定。有效的扩展资源名称采用 example.com/foo 的形式,其中 example.com 被替换为您的组织的域名,而 foo 是一个描述性的资源名称。

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

apiVersion: v1
kind: Pod
metadata:
  name: extended-resource-demo
spec:
  containers:
  - name: extended-resource-demo-ctr
    image: nginx
    resources:
      requests:
        example.com/dongle: 3
      limits:
        example.com/dongle: 3

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

创建 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 的配置文件。容器请求两个 dongle。

apiVersion: v1
kind: Pod
metadata:
  name: extended-resource-demo-2
spec:
  containers:
  - name: extended-resource-demo-2-ctr
    image: nginx
    resources:
      requests:
        example.com/dongle: 2
      limits:
        example.com/dongle: 2

Kubernetes 无法满足对两个 dongle 的请求,因为第一个 Pod 使用了四个可用 dongle 中的三个。

尝试创建 Pod

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

描述 Pod

kubectl describe pod extended-resource-demo-2

输出显示 Pod 无法调度,因为没有节点有 2 个可用的 dongle

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 已创建,但未调度到节点上运行。它处于 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

下一步

对于应用程序开发人员

对于集群管理员

最后修改时间:2023 年 8 月 24 日下午 6:38 PST: 使用 code_sample 短代码代替 code 短代码 (e8b136c3b3)