Configure Default CPU Requests and Limits for a Namespace

    This page shows how to configure default CPU requests and limits for a namespace.

    A Kubernetes cluster can be divided into namespaces. If you create a Pod within a namespace that has a default CPU , and any container in that Pod does not specify its own CPU limit, then the control plane assigns the default CPU limit to that container.

    Kubernetes assigns a default CPU , but only under certain conditions that are explained later in this page.

    You need to have a Kubernetes cluster, and the kubectl command-line tool must be configured to communicate with your cluster. It is recommended to run this tutorial on a cluster with at least two nodes that are not acting as control plane hosts. If you do not already have a cluster, you can create one by using or you can use one of these Kubernetes playgrounds:

    You must have access to create namespaces in your cluster.

    If you’re not already familiar with what Kubernetes means by 1.0 CPU, read meaning of CPU.

    Create a namespace

    Create a namespace so that the resources you create in this exercise are isolated from the rest of your cluster.

    Here’s a manifest for an example . The manifest specifies a default CPU request and a default CPU limit.

    admin/resource/cpu-defaults.yaml

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

    Create the LimitRange in the default-cpu-example namespace:

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

    Now if you create a Pod in the default-cpu-example namespace, and any container in that Pod does not specify its own values for CPU request and CPU limit, then the control plane applies default values: a CPU request of 0.5 and a default CPU limit of 1.

    Here’s a manifest for a Pod that has one container. The container does not specify a CPU request and limit.

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

    Create the Pod.

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

    View the Pod’s specification:

    The output shows that the Pod’s only container has a CPU request of 500m (which you can read as “500 millicpu”), and a CPU limit of 1 cpu. These are the default values specified by the 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

    What if you specify a container’s limit, but not its request?

    Here’s a manifest for a Pod that has one container. The container specifies a CPU limit, but not a request:

    admin/resource/cpu-defaults-pod-2.yaml Configure Default CPU Requests and Limits for a Namespace - 图3

    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. limits:

    Create the Pod:

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

    View the of the Pod that you created:

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

    The output shows that the container’s CPU request is set to match its CPU limit. Notice that the container was not assigned the default CPU request value of 0.5 cpu:

    Here’s an example manifest for a Pod that has one container. The container specifies a CPU request, but not a limit:

    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"

    Create the Pod:

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

    View the specification of the Pod that you created:

    1. kubectl get pod default-cpu-demo-3 --output=yaml --namespace=default-cpu-example
    1. resources:
    2. limits:
    3. cpu: "1"
    4. cpu: 750m

    Motivation for default CPU limits and requests

    If your namespace has a CPU resource quota configured, it is helpful to have a default value in place for CPU limit. Here are two of the restrictions that a CPU resource quota imposes on a namespace:

    • For every Pod that runs in the namespace, each of its containers must have a CPU limit.
    • CPU limits apply a resource reservation on the node where the Pod in question is scheduled. The total amount of CPU that is reserved for use by all Pods in the namespace must not exceed a specified limit.

    When you add a LimitRange:

    If any Pod in that namespace that includes a container does not specify its own CPU limit, the control plane applies the default CPU limit to that container, and the Pod can be allowed to run in a namespace that is restricted by a CPU ResourceQuota.

    Delete your namespace:

    What’s next

    For app developers