为命名空间配置默认的 CPU 请求和限制

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    To check the version, enter .

    创建命名空间

    创建一个命名空间,以便本练习中创建的资源和集群的其余部分相隔离。

    这里给出了 LimitRange 对象的配置文件。该配置声明了一个默认的 CPU 请求和一个默认的 CPU 限制。

    admin/resource/cpu-defaults.yaml

    1. apiVersion: v1
    2. kind: LimitRange
    3. metadata:
    4. name: cpu-limit-range
    5. spec:
    6. limits:
    7. - default:
    8. cpu: 1
    9. defaultRequest:
    10. cpu: 0.5
    11. type: Container

    在命名空间 default-cpu-example 中创建 LimitRange 对象:

    1. kubectl apply -f https://k8s.io/examples/admin/resource/cpu-defaults.yaml --namespace=default-cpu-example

    现在如果在 default-cpu-example 命名空间创建一个容器,该容器没有声明自己的 CPU 请求和限制时, 将会给它指定默认的 CPU 请求0.5和默认的 CPU 限制值1.

    这里给出了包含一个容器的 Pod 的配置文件。该容器没有声明 CPU 请求和限制。

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. spec:
    5. containers:
    6. - name: default-cpu-demo-ctr

    创建 Pod。

    1. kubectl apply -f https://k8s.io/examples/admin/resource/cpu-defaults-pod.yaml --namespace=default-cpu-example

    查看该 Pod 的声明:

    输出显示该 Pod 的容器有一个500 millicpus的 CPU 请求和一个1 cpu的 CPU 限制。这些是 LimitRange 声明的默认值。

    1. containers:
    2. - image: nginx
    3. imagePullPolicy: Always
    4. name: default-cpu-demo-ctr
    5. resources:
    6. limits:
    7. cpu: "1"
    8. requests:
    9. cpu: 500m

    你只声明容器的限制,而不声明请求会怎么样?

    这是包含一个容器的 Pod 的配置文件。该容器声明了 CPU 限制,而没有声明 CPU 请求。

    admin/resource/cpu-defaults-pod-2.yaml

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: default-cpu-demo-2
    5. spec:
    6. containers:
    7. - name: default-cpu-demo-2-ctr
    8. image: nginx
    9. resources:
    10. cpu: "1"

    创建 Pod

    1. kubectl apply -f https://k8s.io/examples/admin/resource/cpu-defaults-pod-2.yaml --namespace=default-cpu-example

    查看 Pod 的声明:

    1. kubectl get pod default-cpu-demo-2 --output=yaml --namespace=default-cpu-example

    输出显示该容器的 CPU 请求和 CPU 限制设置相同。注意该容器没有被指定默认的 CPU 请求值0.5 cpu。

    1. kind: Pod
    2. metadata:
    3. name: default-cpu-demo-3
    4. spec:
    5. containers:
    6. - name: default-cpu-demo-3-ctr
    7. image: nginx
    8. resources:
    9. requests:
    10. cpu: "0.75"

    创建 Pod:

    1. kubectl apply -f https://k8s.io/examples/admin/resource/cpu-defaults-pod-3.yaml --namespace=default-cpu-example

    查看 Pod 的规约:

    1. kubectl get pod default-cpu-demo-3 --output=yaml --namespace=default-cpu-example

    结果显示该容器的 CPU 请求被设置为容器配置文件中声明的数值。 容器的CPU限制被设置为 1 CPU,即该命名空间的默认 CPU 限制值。

    1. resources:
    2. limits:
    3. cpu: "1"
    4. cpu: 750m

    默认 CPU 限制和请求的动机

    如果你的命名空间有一个 , 那么有一个默认的 CPU 限制是有帮助的。这里有资源配额强加给命名空间的两条限制:

    • 命名空间中运行的每个容器必须有自己的 CPU 限制。
    • 命名空间中所有容器使用的 CPU 总和不能超过一个声明值。

    如果容器没有声明自己的 CPU 限制,将会给它一个默认限制,这样它就能被允许运行在一个有配额限制的命名空间中。

    删除你的命名空间:

    What’s next

    应用开发者参考

    最后修改 December 11, 2020 at 9:53 AM PST: Update cpu-default-namespace.md (7e998a73c)