...
파드가 특정 노드에 스케줄링되지 않도록 제한하거나, 특정 조건을 충족하는 노드에만 스케줄링되도록 제어하는 방법입니다.
노드에 Taint를 설정하면 파드가 스케줄링 되지 않으며, Toleration이 있는 파드만 스케줄링될 수 있습니다.
4.1 노드에 Taint 설정
코드 블럭 |
---|
# kubectl taint nodes w2-k8s disktype=ssd:NoSchedule # kubectl describe nodes | grep -i taint |
...
NoSchedule
: 이 Taint를 가진 노드에는 Toleration이 있는 파드만 스케줄링될 수 있습니다.PreferNoSchedule
: 가능하면 이 Taint를 가진 노드에는 Toleration이 있는 파드만 스케줄링하려고 합니다.NoExecute
: Toleration이 없는 기존 파드는 이 노드에서 축출됩니다.
코드 블럭 |
---|
# kubectl taint nodes w2-k8s disktype=ssd:NoSchedule-
node/w2-k8s untainted |
4.2 파드에 Toleration 설정
Tolerations
는 파드에 설정되며, 특정 Taint를 가진 노드에 스케줄링될 수 있도록 허용합니다.
...
disktype=ssd
와NoSchedule
효과를 가진 Taint를 허용하여, 해당 Taint를 가진 노드에 파드를 스케줄링할 수 있도록 합니다.
4.3 노드에 Taint 해제
코드 블럭 |
---|
# kubectl taint nodes w2-k8s disktype=ssd:NoSchedule-
node/w2-k8s untainted |
5. Cordon 및 Uncordon
5.1 Cordon
...