2017-08-07 22:30:29 +00:00
|
|
|
---
|
|
|
|
title: Configure Minimum and Maximum Memory Constraints for a Namespace
|
2018-05-05 16:00:51 +00:00
|
|
|
content_template: templates/task
|
2018-05-20 03:35:51 +00:00
|
|
|
weight: 30
|
2017-08-07 22:30:29 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% capture overview %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
This page shows how to set minimum and maximum values for memory used by Containers
|
|
|
|
running in a namespace. You specify minimum and maximum memory values in a
|
2018-05-05 16:00:51 +00:00
|
|
|
[LimitRange](/docs/reference/generated/kubernetes-api/{{< param "version" >}}/#limitrange-v1-core)
|
2017-08-07 22:30:29 +00:00
|
|
|
object. If a Pod does not meet the constraints imposed by the LimitRange,
|
|
|
|
it cannot be created in the namespace.
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% /capture %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% capture prerequisites %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Each node in your cluster must have at least 1 GiB of memory.
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% /capture %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% capture steps %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
## Create a namespace
|
|
|
|
|
|
|
|
Create a namespace so that the resources you create in this exercise are
|
|
|
|
isolated from the rest of your cluster.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
kubectl create namespace constraints-mem-example
|
|
|
|
```
|
|
|
|
|
|
|
|
## Create a LimitRange and a Pod
|
|
|
|
|
|
|
|
Here's the configuration file for a LimitRange:
|
|
|
|
|
2018-07-03 20:39:21 +00:00
|
|
|
{{< codenew file="admin/resource/memory-constraints.yaml" >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Create the LimitRange:
|
|
|
|
|
|
|
|
```shell
|
2018-07-03 20:39:21 +00:00
|
|
|
kubectl create -f https://k8s.io/examples/admin/resource/memory-constraints.yaml --namespace=constraints-mem-example
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
View detailed information about the LimitRange:
|
|
|
|
|
|
|
|
```shell
|
2017-11-07 23:27:23 +00:00
|
|
|
kubectl get limitrange mem-min-max-demo-lr --namespace=constraints-mem-example --output=yaml
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output shows the minimum and maximum memory constraints as expected. But
|
|
|
|
notice that even though you didn't specify default values in the configuration
|
|
|
|
file for the LimitRange, they were created automatically.
|
|
|
|
|
|
|
|
```
|
|
|
|
limits:
|
|
|
|
- default:
|
|
|
|
memory: 1Gi
|
|
|
|
defaultRequest:
|
|
|
|
memory: 1Gi
|
|
|
|
max:
|
|
|
|
memory: 1Gi
|
|
|
|
min:
|
|
|
|
memory: 500Mi
|
|
|
|
type: Container
|
|
|
|
```
|
|
|
|
|
|
|
|
Now whenever a Container is created in the constraints-mem-example namespace, Kubernetes
|
|
|
|
performs these steps:
|
|
|
|
|
|
|
|
* If the Container does not specify its own memory request and limit, assign the default
|
|
|
|
memory request and limit to the Container.
|
|
|
|
|
|
|
|
* Verify that the Container has a memory request that is greater than or equal to 500 MiB.
|
|
|
|
|
|
|
|
* Verify that the Container has a memory limit that is less than or equal to 1 GiB.
|
|
|
|
|
|
|
|
Here's the configuration file for a Pod that has one Container. The Container manifest
|
|
|
|
specifies a memory request of 600 MiB and a memory limit of 800 MiB. These satisfy the
|
|
|
|
minimum and maximum memory constraints imposed by the LimitRange.
|
|
|
|
|
2018-07-03 20:39:21 +00:00
|
|
|
{{< codenew file="admin/resource/memory-constraints-pod.yaml" >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Create the Pod:
|
|
|
|
|
|
|
|
```shell
|
2018-07-03 20:39:21 +00:00
|
|
|
kubectl create -f https://k8s.io/examples/admin/resource/memory-constraints-pod.yaml --namespace=constraints-mem-example
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Verify that the Pod's Container is running:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
kubectl get pod constraints-mem-demo --namespace=constraints-mem-example
|
|
|
|
```
|
|
|
|
|
|
|
|
View detailed information about the Pod:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
kubectl get pod constraints-mem-demo --output=yaml --namespace=constraints-mem-example
|
|
|
|
```
|
|
|
|
|
|
|
|
The output shows that the Container has a memory request of 600 MiB and a memory limit
|
|
|
|
of 800 MiB. These satisfy the constraints imposed by the LimitRange.
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
resources:
|
|
|
|
limits:
|
|
|
|
memory: 800Mi
|
|
|
|
requests:
|
|
|
|
memory: 600Mi
|
|
|
|
```
|
|
|
|
|
|
|
|
Delete your Pod:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
kubectl delete pod constraints-mem-demo --namespace=constraints-mem-example
|
|
|
|
```
|
|
|
|
|
|
|
|
## Attempt to create a Pod that exceeds the maximum memory constraint
|
|
|
|
|
|
|
|
Here's the configuration file for a Pod that has one Container. The Container specifies a
|
2017-09-22 16:23:59 +00:00
|
|
|
memory request of 800 MiB and a memory limit of 1.5 GiB.
|
2017-08-07 22:30:29 +00:00
|
|
|
|
2018-07-03 20:39:21 +00:00
|
|
|
{{< codenew file="admin/resource/memory-constraints-pod-2.yaml" >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Attempt to create the Pod:
|
|
|
|
|
|
|
|
```shell
|
2018-07-03 20:39:21 +00:00
|
|
|
kubectl create -f https://k8s.io/examples/admin/resource/memory-constraints-pod-2.yaml --namespace=constraints-mem-example
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output shows that the Pod does not get created, because the Container specifies a memory limit that is
|
|
|
|
too large:
|
|
|
|
|
|
|
|
```
|
2018-07-03 20:39:21 +00:00
|
|
|
Error from server (Forbidden): error when creating "examples/admin/resource/memory-constraints-pod-2.yaml":
|
2017-08-07 22:30:29 +00:00
|
|
|
pods "constraints-mem-demo-2" is forbidden: maximum memory usage per Container is 1Gi, but limit is 1536Mi.
|
|
|
|
```
|
|
|
|
|
|
|
|
## Attempt to create a Pod that does not meet the minimum memory request
|
|
|
|
|
|
|
|
Here's the configuration file for a Pod that has one Container. The Container specifies a
|
2018-10-09 12:15:31 +00:00
|
|
|
memory request of 100 MiB and a memory limit of 800 MiB.
|
2017-08-07 22:30:29 +00:00
|
|
|
|
2018-07-03 20:39:21 +00:00
|
|
|
{{< codenew file="admin/resource/memory-constraints-pod-3.yaml" >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Attempt to create the Pod:
|
|
|
|
|
|
|
|
```shell
|
2018-07-03 20:39:21 +00:00
|
|
|
kubectl create -f https://k8s.io/examples/admin/resource/memory-constraints-pod-3.yaml --namespace=constraints-mem-example
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output shows that the Pod does not get created, because the Container specifies a memory
|
|
|
|
request that is too small:
|
|
|
|
|
|
|
|
```
|
2018-07-03 20:39:21 +00:00
|
|
|
Error from server (Forbidden): error when creating "examples/admin/resource/memory-constraints-pod-3.yaml":
|
2017-08-07 22:30:29 +00:00
|
|
|
pods "constraints-mem-demo-3" is forbidden: minimum memory usage per Container is 500Mi, but request is 100Mi.
|
|
|
|
```
|
|
|
|
|
2017-08-25 18:06:59 +00:00
|
|
|
## Create a Pod that does not specify any memory request or limit
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Here's the configuration file for a Pod that has one Container. The Container does not
|
|
|
|
specify a memory request, and it does not specify a memory limit.
|
|
|
|
|
2018-07-03 20:39:21 +00:00
|
|
|
{{< codenew file="admin/resource/memory-constraints-pod-4.yaml" >}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
Create the Pod:
|
|
|
|
|
|
|
|
```shell
|
2018-07-03 20:39:21 +00:00
|
|
|
kubectl create -f https://k8s.io/examples/admin/resource/memory-constraints-pod-4.yaml --namespace=constraints-mem-example
|
2017-08-07 22:30:29 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
View detailed information about the Pod:
|
|
|
|
|
|
|
|
```
|
|
|
|
kubectl get pod constraints-mem-demo-4 --namespace=constraints-mem-example --output=yaml
|
|
|
|
```
|
|
|
|
|
|
|
|
The output shows that the Pod's Container has a memory request of 1 GiB and a memory limit of 1 GiB.
|
|
|
|
How did the Container get those values?
|
|
|
|
|
|
|
|
```
|
|
|
|
resources:
|
|
|
|
limits:
|
|
|
|
memory: 1Gi
|
|
|
|
requests:
|
|
|
|
memory: 1Gi
|
|
|
|
```
|
|
|
|
|
|
|
|
Because your Container did not specify its own memory request and limit, it was given the
|
2017-08-15 07:14:16 +00:00
|
|
|
[default memory request and limit](/docs/tasks/administer-cluster/memory-default-namespace/)
|
2017-08-07 22:30:29 +00:00
|
|
|
from the LimitRange.
|
|
|
|
|
|
|
|
At this point, your Container might be running or it might not be running. Recall that a prerequisite
|
|
|
|
for this task is that your Nodes have at least 1 GiB of memory. If each of your Nodes has only
|
|
|
|
1 GiB of memory, then there is not enough allocatable memory on any Node to accommodate a memory
|
|
|
|
request of 1 GiB. If you happen to be using Nodes with 2 GiB of memory, then you probably have
|
|
|
|
enough space to accommodate the 1 GiB request.
|
|
|
|
|
|
|
|
Delete your Pod:
|
|
|
|
|
|
|
|
```
|
|
|
|
kubectl delete pod constraints-mem-demo-4 --namespace=constraints-mem-example
|
|
|
|
```
|
|
|
|
|
|
|
|
## Enforcement of minimum and maximum memory constraints
|
|
|
|
|
|
|
|
The maximum and minimum memory constraints imposed on a namespace by a LimitRange are enforced only
|
|
|
|
when a Pod is created or updated. If you change the LimitRange, it does not affect
|
|
|
|
Pods that were created previously.
|
|
|
|
|
|
|
|
## Motivation for minimum and maximum memory constraints
|
|
|
|
|
|
|
|
As a cluster administrator, you might want to impose restrictions on the amount of memory that Pods can use.
|
|
|
|
For example:
|
|
|
|
|
|
|
|
* Each Node in a cluster has 2 GB of memory. You do not want to accept any Pod that requests
|
|
|
|
more than 2 GB of memory, because no Node in the cluster can support the request.
|
|
|
|
|
|
|
|
* A cluster is shared by your production and development departments.
|
|
|
|
You want to allow production workloads to consume up to 8 GB of memory, but
|
|
|
|
you want development workloads to be limited to 512 MB. You create separate namespaces
|
|
|
|
for production and development, and you apply memory constraints to each namespace.
|
|
|
|
|
|
|
|
## Clean up
|
|
|
|
|
|
|
|
Delete your namespace:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
kubectl delete namespace constraints-mem-example
|
|
|
|
```
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% /capture %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% capture whatsnext %}}
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
### For cluster administrators
|
|
|
|
|
2017-08-16 02:19:58 +00:00
|
|
|
* [Configure Default Memory Requests and Limits for a Namespace](/docs/tasks/administer-cluster/memory-default-namespace/)
|
2017-08-07 22:30:29 +00:00
|
|
|
|
2017-08-16 01:18:48 +00:00
|
|
|
* [Configure Default CPU Requests and Limits for a Namespace](/docs/tasks/administer-cluster/cpu-default-namespace/)
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
* [Configure Minimum and Maximum CPU Constraints for a Namespace](/docs/tasks/administer-cluster/cpu-constraint-namespace/)
|
|
|
|
|
|
|
|
* [Configure Memory and CPU Quotas for a Namespace](/docs/tasks/administer-cluster/quota-memory-cpu-namespace/)
|
|
|
|
|
|
|
|
* [Configure a Pod Quota for a Namespace](/docs/tasks/administer-cluster/quota-pod-namespace/)
|
|
|
|
|
|
|
|
* [Configure Quotas for API Objects](/docs/tasks/administer-cluster/quota-api-object/)
|
|
|
|
|
|
|
|
### For app developers
|
|
|
|
|
|
|
|
* [Assign Memory Resources to Containers and Pods](/docs/tasks/configure-pod-container/assign-memory-resource/)
|
|
|
|
|
2017-08-15 05:39:25 +00:00
|
|
|
* [Assign CPU Resources to Containers and Pods](/docs/tasks/configure-pod-container/assign-cpu-resource/)
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
* [Configure Quality of Service for Pods](/docs/tasks/configure-pod-container/quality-service-pod/)
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
{{% /capture %}}
|
|
|
|
|
2017-08-07 22:30:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|