在K8S中,Pod亲和性和反亲和性作用区别有哪些?该如何使用?

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 在K8S中,Pod亲和性和反亲和性作用区别有哪些?该如何使用?
1.Pod亲和性 (Pod Affinity)

作用

  • 资源协同:当Pod需要与具有特定标签的Node或已经在特定Node上运行的Pod紧密合作时,比如共享硬件加速器或者进行高效的数据交互,可以利用Pod亲和性将这些Pod调度到一起。
  • 负载分片:在大规模集群中,可以根据业务需求,将相似类型的Pod调度到同一组Node上,以实现数据局部性、减少网络开销或优化整体性能。

如何使用

Pod亲和性通过affinity字段中的podAffinitynodeAffinity设置。例如,创建一个Deployment时,可以在其YAML配置文件中添加以下内容:

spec:
affinity:
podAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- labelSelector:
matchExpressions:
- key: app
operator: In
values: ["myapp"]
topologyKey: "kubernetes.io/hostname"
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: zone
operator: In
values: ["us-west1-a"]

在这个例子中,我们设置了两个亲和性规则:

  • Pod亲和性:要求Pod被调度到那些已经运行了标签为app=myapp的Pod的节点上,且依据kubernetes.io/hostname这一拓扑键进行判断。
  • Node亲和性:强制Pod只能被调度到标签为zone=us-west1-a的节点上。
2.Pod反亲和性 (Pod Anti-Affinity)

作用

  • 高可用性:为了确保服务的冗余性和容错性,可以设置Pod反亲和性,让相同服务的不同实例分布在不同的Node上,以避免单一节点故障影响整个服务。
  • 资源隔离:当一些Pod消耗大量资源,为了避免资源竞争或达到更好的负载均衡效果,可以设置反亲和性,确保这些Pod不会被调度到同一台机器上。

如何使用

同样在affinity字段中设置podAntiAffinitynodeAntiAffinity。例如:

spec:
affinity:
podAntiAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- labelSelector:
matchExpressions:
- key: app
operator: In
values: ["myapp"]
topologyKey: "kubernetes.io/hostname"
nodeAntiAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: failure-domain.beta.kubernetes.io/zone
operator: NotIn
values: ["us-west1-a"]

这个例子中,我们指定了两个反亲和性规则:

  • Pod反亲和性:强制当前Pod不能与标签为app=myapp的Pod调度到同一台机器上,依然是基于kubernetes.io/hostname拓扑键判断。
  • Node反亲和性:强制Pod不能被调度到标签为failure-domain.beta.kubernetes.io/zone=us-west1-a的节点上,从而实现跨Zone的高可用部署。
3.区别:
  • 方向性: Pod亲和性强调的是Pod间的聚集或关联调度,而反亲和性则是强调Pod间的分离或避免共同调度。
  • 目的: 亲和性通常用于提高服务间协作效率或平衡资源分布;反亲和性更多是为了增强服务的冗余性和故障恢复能力。
  • 效果: 设置亲和性可能导致相关Pod在物理上或逻辑上更加接近;设置反亲和性则促使Pod尽可能远离某些特定的Pod或节点。

综上所述,在实际应用中,Kubernetes 的Pod亲和性和反亲和性提供了灵活的调度策略,帮助运维人员更好地管理分布式系统的可靠性和性能。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
13天前
|
Kubernetes API 调度
k8s中节点无法启动Pod
【10月更文挑战第3天】
48 6
|
13天前
|
存储 Kubernetes Perl
K8S中Pod启动异常
【10月更文挑战第3天】
28 2
|
15天前
|
应用服务中间件 调度 nginx
Kubernetes的Pod调度:让你的应用像乘坐头等舱!
Kubernetes的Pod调度:让你的应用像乘坐头等舱!
|
19天前
|
Kubernetes API 调度
k8s学习--pod的所有状态详解(图例展示)
k8s学习--pod的所有状态详解(图例展示)
|
15天前
|
JSON Kubernetes API
在K8S中,什么是静态Pod?
在K8S中,什么是静态Pod?
|
17天前
|
Kubernetes 应用服务中间件 调度
k8s的Pod常见的几种调度形式
k8s的Pod常见的几种调度形式
17 0
|
19天前
|
Kubernetes 固态存储 调度
k8s学习--如何控制pod调度的位置
k8s学习--如何控制pod调度的位置
|
20天前
|
Kubernetes Cloud Native 云计算
云原生之旅:Kubernetes 集群的搭建与实践
【8月更文挑战第67天】在云原生技术日益成为IT行业焦点的今天,掌握Kubernetes已成为每个软件工程师必备的技能。本文将通过浅显易懂的语言和实际代码示例,引导你从零开始搭建一个Kubernetes集群,并探索其核心概念。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你打开一扇通往云原生世界的大门。
90 17
|
13天前
|
Kubernetes 应用服务中间件 nginx
搭建Kubernetes v1.31.1服务器集群,采用Calico网络技术
在阿里云服务器上部署k8s集群,一、3台k8s服务器,1个Master节点,2个工作节点,采用Calico网络技术。二、部署nginx服务到k8s集群,并验证nginx服务运行状态。
112 1
|
18天前
|
Kubernetes Cloud Native 微服务
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
59 1