Node Scheduling
Node Affinity, Pod Affinity/Anti-Affinity, Toleration/Taint
data:image/s3,"s3://crabby-images/87771/87771c2c9747adea38f0d6162af3c4f49a93e55c" alt="Scheduling with Affinity and Toleration Taint for Kubernetes."
1. Node Affinity
data:image/s3,"s3://crabby-images/52b3f/52b3f0023cabe956023933b2020c43fd4bfdc469" alt="Scheduling of Node Affinity for Kubernetes."
1-1) Node Labeling
kubectl label nodes k8s-node1 kr=az-1
kubectl label nodes k8s-node2 us=az-1
1-2) MatchExpressions
apiVersion: v1
kind: Pod
metadata:
name: pod-match-expressions1
spec:
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- {key: kr, operator: Exists}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
1-3) Required
apiVersion: v1
kind: Pod
metadata:
name: pod-required
spec:
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- {key: ch, operator: Exists}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
1-4) Preferred
apiVersion: v1
kind: Pod
metadata:
name: pod-preferred
spec:
affinity:
nodeAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
preference:
matchExpressions:
- {key: ch, operator: Exists}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
2. Pod Affinity / Anti-Affinity
data:image/s3,"s3://crabby-images/b993e/b993e0f43d4c94b2a7eb75e4c9773aa8da6f8f89" alt="Scheduling of Pod Affinity for Kubernetes."
2-1) Node Labeling
kubectl label nodes k8s-node1 a-team=1
kubectl label nodes k8s-node2 a-team=2
2-2) Web1 Pod
apiVersion: v1
kind: Pod
metadata:
name: web1
labels:
type: web1
spec:
nodeSelector:
a-team: '1'
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
2-3) Web1 Affinity Pod
apiVersion: v1
kind: Pod
metadata:
name: server1
spec:
affinity:
podAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- topologyKey: a-team
labelSelector:
matchExpressions:
- {key: type, operator: In, values: [web1]}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
2-4) Web2 Affinity Pod
apiVersion: v1
kind: Pod
metadata:
name: server2
spec:
affinity:
podAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- topologyKey: a-team
labelSelector:
matchExpressions:
- {key: type, operator: In, values: [web2]}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
2-5) Web2 Pod
apiVersion: v1
kind: Pod
metadata:
name: web2
labels:
type: web2
spec:
nodeSelector:
a-team: '2'
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
data:image/s3,"s3://crabby-images/7397d/7397d7018542e630d5f11a0fed5e74cb712de780" alt="Scheduling of Pod Anti-Affinity for Kubernetes."
2-6) Master Pod
apiVersion: v1
kind: Pod
metadata:
name: master
labels:
type: master
spec:
nodeSelector:
a-team: '1'
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
2-7) Master Anti-Affinity Pod
apiVersion: v1
kind: Pod
metadata:
name: slave
spec:
affinity:
podAntiAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- topologyKey: a-team
labelSelector:
matchExpressions:
- {key: type, operator: In, values: [master]}
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
3. Taint / Toleration
data:image/s3,"s3://crabby-images/37717/37717a59adc7fb051ffca39d35b6b1bbc9452500" alt="Scheduling of Taint and Toleration for Kubernetes."
3-1) Node Labeling
kubectl label nodes k8s-node1 gpu=no1
3-2) Node1 - Taint
kubectl taint nodes k8s-node1 hw=gpu:NoSchedule
3-3) Pod with Toleration
apiVersion: v1
kind: Pod
metadata:
name: pod-with-toleration
spec:
nodeSelector:
gpu: no1
tolerations:
- effect: NoSchedule
key: hw
operator: Equal
value: gpu
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
3-4) Pod without Toleration
apiVersion: v1
kind: Pod
metadata:
name: pod-without-toleration
spec:
nodeSelector:
gpu: no1
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
3-5) Pod1 with NoExecute
apiVersion: v1
kind: Pod
metadata:
name: pod1-with-no-execute
spec:
tolerations:
- effect: NoExecute
key: out-of-disk
operator: Exists
tolerationSeconds: 30
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
3-6) Pod2 with NoExecute
apiVersion: v1
kind: Pod
metadata:
name: pod2-without-no-execute
spec:
containers:
- name: container
image: kubetm/app
terminationGracePeriodSeconds: 0
3-7) Node2 - Taint
kubectl taint nodes k8s-node1 hw=gpu:NoSchedule-
kubectl taint nodes k8s-node2 out-of-disk=True:NoExecute
필독! 작업 후 Taint 꼭 삭제해주세요
kubectl taint nodes k8s-node2 out-of-disk=True:NoExecute-Sample Yaml
NodeName
apiVersion: v1
kind: Pod
metadata:
name: node-name
spec:
nodeName: k8s-node1
containers:
- name: container
image: kubetm/app
NodeSelector
apiVersion: v1
kind: Pod
metadata:
name: node-selector
spec:
nodeSelector:
key1:value1
containers:
- name: container
image: kubetm/app
kubectl
Label
# Node에 라벨 추가
kubectl label nodes k8s-node1 key1=value1
# Node에 라벨 삭제
kubectl label nodes k8s-node1 key1=value1-
Tips
NodeAffinity MatchExpressions Operator
data:image/s3,"s3://crabby-images/60cea/60ceafa5667e3b50e3be0204eb625ff52d9f5fe2" alt="Scheduling MatchExpressions for Kubernetes."
Referenece
Kubernetes
- Assigning Pods to Nodes : https://kubernetes.io/docs/concepts/configuration/assign-pod-node
- Taints and Tolerations : https://kubernetes.io/docs/concepts/configuration/taint-and-toleration