为容器分配扩展资源
特性状态:
Kubernetes v1.34 [stable]
本页面展示了如何为容器分配扩展资源。
准备工作
你需拥有一个 Kubernetes 集群,并且 kubectl 命令行工具已配置为与你的集群通信。 建议在至少包含两个不作为控制平面主机的节点的集群上运行本教程。 如果你还没有集群,你可以使用 minikube 创建一个,或者使用这些 Kubernetes 游乐场之一
要检查版本,请输入 kubectl version
。
在执行此练习之前,请先完成 为节点通告扩展资源 中的练习。 这将配置你的一个节点以通告一个“加密狗”资源。
为 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 个加密狗。
创建一个 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
输出显示了加密狗请求
Limits:
example.com/dongle: 3
Requests:
example.com/dongle: 3
尝试创建第二个 Pod
以下是包含一个容器的 Pod 的配置文件。 该容器请求两个加密狗。
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 将无法满足对两个加密狗的请求,因为第一个 Pod 使用了四个可用加密狗中的三个。
尝试创建一个 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 个加密狗的节点
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)