在 Kubernetes(K8s)中,Pod 调度亲和性(Affinity) 是一种高级调度策略,用于控制 Pod 与节点(Node)或其他 Pod 之间的关联(亲和)或反关联(反亲和)关系。通过亲和性规则,管理员可以更精细地控制 Pod 的调度行为,满足业务的拓扑约束、资源局部性、高可用等需求。
亲和性主要有两类
[root@master ~/affinity]# kubectl get po | awk '{print $1}' | xargs kubectl delete po
pod "nginx-affinity-556d5d5987-5bnjm" deleted
pod "nginx-affinity-556d5d5987-bvmvh" deleted
pod "nginx-affinity-556d5d5987-d7tkg" deleted
pod "nginx-affinity-556d5d5987-frkkm" deleted
pod "nginx-affinity-556d5d5987-ttlcr" deleted
复制代码
查看Pod,发现状态都是Pending状态
[root@master ~/affinity]# kubectl get po
NAME READY STATUS RESTARTS AGE
nginx-affinity-556d5d5987-44qmc 0/1 Pending 0 27s
nginx-affinity-556d5d5987-4qtth 0/1 Pending 0 27s
nginx-affinity-556d5d5987-4tws5 0/1 Pending 0 27s
nginx-affinity-556d5d5987-bgm7n 0/1 Pending 0 27s
nginx-affinity-556d5d5987-kh555 0/1 Pending 0 27s
复制代码
查看一下详细信息,发现是标签不匹配
[root@master ~/affinity]# kubectl describe po nginx-affinity-556d5d5987-44qmc
Name: nginx-affinity-556d5d5987-44qmc
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Warning FailedScheduling 71s default-scheduler 0/3 nodes are available: 1 node(s) had untolerated taint {node-role.kubernetes.io/control-plane: }, 2 node(s) didn't match Pod's node affinity/selector. preemption: 0/3 nodes are available: 3 Preemption is not helpful for scheduling..
Warning FailedScheduling 70s default-scheduler 0/3 nodes are available: 1 node(s) had untolerated taint {node-role.kubernetes.io/control-plane: }, 2 node(s) didn't match Pod's node affinity/selector. preemption: 0/3 nodes are available: 3 Preemption is not helpful for scheduling..
Pod 亲和性(Pod Affinity)是 Kubernetes 中控制 Pod 调度的重要机制,其核心作用是根据其他 Pod 的位置(如节点、命名空间等)来影响当前 Pod 的调度决策,实现 Pod 之间的协同部署或反亲和(互斥部署)。这一机制通过标签匹配规则,将相关 Pod 「吸引」到同一区域(如节点、机架、可用区等)或「排斥」到不同区域,从而优化资源利用、提升服务性能或增强系统稳定性。
Pod亲和性的分类
配置说明:
labelSelector:标签选择器,在这里是选择Pod的标签,而不是选择节点的标签,因为Pod亲和性是Pod级别的调度
topologyKey:该字段是Pod亲和性中一个很重要的字段,它的作用是定义 Pod 亲和性或反亲和性规则的作用范围,即在什么级别的拓扑结构中应用这些规则。这里指定的节点标签的key
查看Pod的调度,发现Pod都在node02节点上
[root@master ~/affinity]# kubectl get po -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
Pod 反亲和性(podAntiAffinity)是 Kubernetes 中的一种调度策略,与 Pod 亲和性(podAffinity)相对。它用于控制 Pod 的调度位置,确保满足特定条件的 Pod 不会被调度到同一拓扑层级(如同一节点、同一可用区或同一区域)上。Pod 反亲和性主要用于实现高可用性和资源隔离等目标。
Pod 反亲和性也分为硬性限制和软性限制,通过requiredDuringSchedulingIgnoredDuringExecution(硬性)和 preferredDuringSchedulingIgnoredDuringExecution(软性)来指定。
Pod反亲和性作用
高可用性:
通过将多个副本 Pod 分布到不同的故障域(如不同的节点或可用区),确保系统的容错能力。例如,将多个副本 Pod 调度到不同的节点或可用区,避免单点故障导致所有副本同时不可用。
资源隔离:
通过将某些 Pod 分布到不同的节点或可用区,避免它们相互竞争资源。例如,将不同租户的 Pod 分布到不同的节点或可用区,实现资源隔离。