任务

Kubernetes v1.12 版本的文档已不再维护。您现在看到的版本来自于一份静态的快照。如需查阅最新文档,请点击 最新版本。

Edit This Page

给容器分配非透明整型资源

本页展示了如何给容器分配非透明整型资源。

FEATURE STATE: Kubernetes v1.12 alpha
该功能目前处于 alpha 状态,意味着:

  • 版本名称包含 alpha(例如 v1alpha1)。
  • 可能存在问题,启用该功能可能会暴露 bug。默认情况下被禁用。
  • 对该功能的支持可能在任何时候被取消,而不另行通知。
  • API 可能会在以后的软件版本中以不兼容的方式被更改,而不另行通知。
  • 建议仅在短期测试集群中使用该功能,这是因为使用该功能会增加出现 bug 的风险,而且缺乏长期支持。

准备开始

您必须拥有一个 Kubernetes 集群,并且必须使用 kubectl 命令行工具与你的集群进行通信。如果您还没有一个集群,您可以通过 Minikube 创建一个集群,或者使用这些 Kubernetes playground :

To check the version, enter kubectl version.

在做这个练习之前,请在给节点配置非透明整型资源文档中进行练习, 该文档介绍了在一个节点上配置dongle资源。

给Pod分配非透明整型资源

为了请求一个非透明整型资源,需要在容器配置文件中包含resources:requests字段。 非透明整型资源类型前缀是pod.alpha.kubernetes.io/opaque-int-resource-

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

oir-pod.yaml docs/tasks/configure-pod-container
apiVersion: v1
kind: Pod
metadata:
  name: oir-demo
spec:
  containers:
  - name: oir-demo-ctr
    image: nginx
    resources:
      requests:
        pod.alpha.kubernetes.io/opaque-int-resource-dongle: 3

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

创建Pod:

kubectl create -f https://k8s.io/docs/tasks/configure-pod-container/oir-pod.yaml

验证Pod是否正在运行:

kubectl get pod oir-demo

查询Pod的状态:

kubectl describe pod oir-demo

输出显示了dongle请求:

Requests:
  pod.alpha.kubernetes.io/opaque-int-resource-dongle: 3

尝试创建第二个Pod

下面是含有一个容器的Pod的配置文件。该容器请求了两个dongles资源。

oir-pod-2.yaml docs/tasks/configure-pod-container
apiVersion: v1
kind: Pod
metadata:
  name: oir-demo-2
spec:
  containers:
  - name: oir-demo-2-ctr
    image: nginx
    resources:
      requests:
        pod.alpha.kubernetes.io/opaque-int-resource-dongle: 2

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

尝试创建Pod:

kubectl create -f https://k8s.io/docs/tasks/configure-pod-container/oir-pod-2.yaml

查询Pod的状态

kubectl describe pod oir-demo-2

输出显示该Pod无法被调度,因为没有节点有两个可用的dongles资源:

Conditions:
  Type    Status
  PodScheduled  False
...
Events:
  ...
  ... Warning   FailedScheduling  pod (oir-demo-2) failed to fit in any node
fit failure summary on nodes : Insufficient pod.alpha.kubernetes.io/opaque-int-resource-dongle (1)

查看Pod的状态:

kubectl get pod oir-demo-2

输出显示Pod已创建,但是没有被调度并运行在节点上。 它的状态为Pending:

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

删除

删除本练习中创建的Pod:

kubectl delete pod oir-demo

接下来

对于应用开发者

对于集群管理员

反馈