Tasks

Step-by-step instructions for performing operations with Kubernetes.

Edit This Page

将扩展资源分配给容器

本文展示了如何将扩展资源分配给容器。

FEATURE STATE: Kubernetes v1.9 stable

This feature is stable, meaning:

  • The version name is vX where X is an integer.
  • Stable versions of features will appear in released software for many subsequent versions.

Before you begin

You need to have a Kubernetes cluster, and the kubectl command-line tool must be configured to communicate with your cluster. If you do not already have a cluster, you can create one by using Minikube, or you can use one of these Kubernetes playgrounds:

To check the version, enter kubectl version.

在进行这里的练习前,您需要先进行 为节点发布扩展资源 中的练习。 在该练习中,您会配置一个节点,使其发布一种 “dongle” 资源。

将扩展资源分配给 Pod

为请求扩展资源,您需要在您的容器 manifest 中包含 resources:requests 字段。 扩展资源完全限定于 *.kubernetes.io/ 外的任何域中。 合法的扩展资源名称形如 example.com/foo,其中 example.com 需要替换为您的组织的域, foo 是一个描述性的资源名称。

这里是拥有一个容器的 Pod 的配置文件:

extended-resource-pod.yaml
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 create -f https://k8s.io/docs/tasks/configure-pod-container/extended-resource-pod.yaml

确认 Pod 正在运行:

kubectl get pod extended-resource-demo

使用 “describe” 命令查看 Pod 详情:

kubectl describe pod extended-resource-demo

输出展示了 “dongle” 资源的请求:

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

尝试创建第二个 Pod

这里是拥有一个容器的 Pod 的配置文件。 容器请求两个 “dongle” 资源。

extended-resource-pod-2.yaml
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” 资源中的三个。

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

使用 “describe” 命令查看 Pod 详情:

kubectl describe pod extended-resource-demo-2

输出显示该 Pod 无法被调度,因为没有存在两个可用 “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-2

What’s next

针对应用开发人员

针对集群管理员

Analytics

Create an Issue Edit this Page