介绍
在 Kubernetes 中,亲和性(Affinity)是一种用于控制 Pod 调度的机制,它允许你指定 Pod 如何与节点进行互动,以便将 Pod 调度到合适的节点上。亲和性可以分为两种类型:节点亲和性(Node Affinity)和 Pod 亲和性(Pod Affinity)。
节点亲和性(Node Affinity)
开始之前需要先给节点打标签,不知道怎样打标签可以看这篇文章
## 先查看所有节点的标签
kubectl get nodes --show-labels
## 给其中一个节点打标签
kubectl label nodes node01 disktype=ssd
节点亲和性有两种
硬亲和性 requiredDuringSchedulingIgnoredDuringExecution
指定了 Pod 必须调度到具有指定特征的节点上,如果没有满足条件的节点则 Pod 不会被调度。
举例:
apiVersion: v1
kind: Pod
metadata:
name: nginx
spec:
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution: # 硬亲和性
nodeSelectorTerms:
- matchExpressions:
- key: disktype
operator: In
values:
- ssd
containers:
- name: nginx
image: nginx
imagePullPolicy: IfNotPresent
这个Pod正常会部署到node01上面。
字段解释:
- affinity: 这是 Pod 配置中的一个字段,用于定义亲和性规则。
- nodeAffinity: 指定了节点亲和性规则。
- requiredDuringSchedulingIgnoredDuringExecution: 这是一个硬亲和性规则,表示 Pod 必须被调度到满足条件的节点上,否则将无法调度。
- nodeSelectorTerms: 用于指定匹配条件的节点选择器条款。
- matchExpressions: 定义了节点选择器的匹配表达式。
- key: disktype: 指定了匹配条件的键,这里是磁盘类型(disktype)。
- operator: In: 指定了匹配操作符,这里是 “In”,表示匹配键的值在指定的值列表中。
- values: - ssd: 指定了匹配条件的值列表,这里只有一个值 “ssd”,表示磁盘类型为 SSD 的节点符合条件。
operator 参数解释:
下面是你可以在上述 nodeAffinity 和 podAffinity 的 operator 字段中可以使用的所有逻辑运算符。
- In 标签值存在于提供的字符串集中
- NotIn 标签值不包含在提供的字符串集中
- Exists 对象上存在具有此键的标签
- DoesNotExist 对象上不存在具有此键的标签
以下操作符只能与 nodeAffinity 一起使用:
- Gt 提供的值将被解析为整数,并且该整数小于通过解析此选择算符命名的标签的值所得到的整数
- Lt 提供的值将被解析为整数,并且该整数大于通过解析此选择算符命名的标签的值所得到的整数
简单应用
这是部分yaml文件
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions: