73 lines
2.4 KiB
Markdown
73 lines
2.4 KiB
Markdown
# cgroups
|
||
|
||
To avoid the rivals for resources between containers or the impact on the host in Kubernetes, the kubelet components will rely on cgroups to limit the container’s resources usage.
|
||
|
||
## Enforcing Node Allocatable
|
||
|
||
You can use `kubelet_enforce_node_allocatable` to set node allocatable enforcement.
|
||
|
||
```yaml
|
||
# A comma separated list of levels of node allocatable enforcement to be enforced by kubelet.
|
||
kubelet_enforce_node_allocatable: "pods"
|
||
# kubelet_enforce_node_allocatable: "pods,kube-reserved"
|
||
# kubelet_enforce_node_allocatable: "pods,kube-reserved,system-reserved"
|
||
```
|
||
|
||
Note that to enforce kube-reserved or system-reserved, `kube_reserved_cgroups` or `system_reserved_cgroups` needs to be specified respectively.
|
||
|
||
Here is an example:
|
||
|
||
```yaml
|
||
kubelet_enforce_node_allocatable: "pods,kube-reserved,system-reserved"
|
||
|
||
# Reserve this space for kube resources
|
||
# Set to true to reserve resources for kube daemons
|
||
kube_reserved: true
|
||
kube_reserved_cgroups_for_service_slice: kube.slice
|
||
kube_reserved_cgroups: "/{{ kube_reserved_cgroups_for_service_slice }}"
|
||
kube_memory_reserved: 256Mi
|
||
kube_cpu_reserved: 100m
|
||
# kube_ephemeral_storage_reserved: 2Gi
|
||
# kube_pid_reserved: "1000"
|
||
# Reservation for master hosts
|
||
kube_master_memory_reserved: 512Mi
|
||
kube_master_cpu_reserved: 200m
|
||
# kube_master_ephemeral_storage_reserved: 2Gi
|
||
# kube_master_pid_reserved: "1000"
|
||
|
||
# Set to true to reserve resources for system daemons
|
||
system_reserved: true
|
||
system_reserved_cgroups_for_service_slice: system.slice
|
||
system_reserved_cgroups: "/{{ system_reserved_cgroups_for_service_slice }}"
|
||
system_memory_reserved: 512Mi
|
||
system_cpu_reserved: 500m
|
||
# system_ephemeral_storage_reserved: 2Gi
|
||
# system_pid_reserved: "1000"
|
||
# Reservation for master hosts
|
||
system_master_memory_reserved: 256Mi
|
||
system_master_cpu_reserved: 250m
|
||
# system_master_ephemeral_storage_reserved: 2Gi
|
||
# system_master_pid_reserved: "1000"
|
||
```
|
||
|
||
After the setup, the cgroups hierarchy is as follows:
|
||
|
||
```bash
|
||
/ (Cgroups Root)
|
||
├── kubepods.slice
|
||
│ ├── ...
|
||
│ ├── kubepods-besteffort.slice
|
||
│ ├── kubepods-burstable.slice
|
||
│ └── ...
|
||
├── kube.slice
|
||
│ ├── ...
|
||
│ ├── {{container_manager}}.service
|
||
│ ├── kubelet.service
|
||
│ └── ...
|
||
├── system.slice
|
||
│ └── ...
|
||
└── ...
|
||
```
|
||
|
||
You can learn more in the [official kubernetes documentation](https://kubernetes.io/docs/tasks/administer-cluster/reserve-compute-resources/).
|