目录
1 节点调度
一般而言pod的调度都是通过RC、Deployment等控制器自动完成,但是仍可以通过手动配置的方式进行调度,目的就是让pod的调度符合我们的预期。
Pod.spec.nodeName
用于强制约束将Pod调度到指定的Node节点上,这里说是“调度”,但其实指定了nodeName的Pod会直接跳过Scheduler的调度逻辑,直接写入PodList列表,该匹配规则是强制匹配。
1.1 创建资源清单
vi pod-node-dispatch.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
spec:
replicas: 1
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
nodeName: node1 #指定调度节点为node1
containers:
- name: nginx
image: nginx:1.20
ports:
- containerPort: 80
1.2 应用部署
kubectl apply -f pod-node-selector-dispatch.yml
kubectl get pods -o wide
1.3 删除pod
kubectl delete pod nginx-deployment-5dc7769598-n25q5
2 定向调度(标签调度)
定向调度是把pod调度到具有特定标签的node节点的一种调度方式,比如把MySQL数据库调度到具有SSD的node节点以优化数据库性能。此时需要首先给指定的node打上标签,并在pod中设置nodeSelector属性以完成pod的指定调度。
2.1 创建标签
2.1.1 添加标签
kubectl label nodes node2 disk=ssd
2.1.2 显示标签
kubectl label node node2 --list=true
2.3 创建资源清单
vi pod-node-selector-dispatch.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
spec:
replicas: 2
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
nodeSelector:
disk: ssd # 节点调度到
containers:
- name: nginx
image: nginx:1.20
ports:
- containerPort: 80
2.4 应用部署
kubectl apply -f pod-node-selector-dispatch.yml
kubectl get pods -o wide
2.5 删除pod
kubectl delete pod nginx-deployment-5dc7769598-n25q5
注意:定向调度可以把pod调度到特定的node节点,但随之而来的缺点就是如果集群中不存在响应的node,即使有基本满足条件的node节点,pod也不会被调度