K8S QoS等级

在 Kubernetes (K8S) 中,QoS(Quality of Service,服务质量)等级用于定义 Pod 在资源调度和管理过程中的优先级,确保在资源紧张时能够更好地管理和分配资源。Kubernetes 根据 Pod 的资源请求和限制将 Pod 分为三种 QoS 等级:

1. Guaranteed (保证)

当一个 Pod 中的所有容器都同时满足以下条件时,该 Pod 被分配为 Guaranteed` 等级:

  • 所有容器都设置了 CPU 和内存的requests limits ,且requests 等于 limits

这意味着容器需要使用多少资源(requests),就限制在这个范围内(limits)。 Guaranteed 等级的 Pod 在集群中有最高优先级,在资源争夺时最不容易被驱逐(evict)。

适用场景:

适用于关键任务工作负载,这些工作负载必须得到稳定的资源分配,并且不能因为资源紧张而被驱逐。

qos类型是Guaranteed测试pod例子,requests 等于 limits

bash 复制代码
---
##pod yaml如下:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: nginx
    image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/nginx:stable
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80
    resources:
      limits:       #####requests与limit的值相等
        cpu: 300m
        memory: 400Mi
      requests:
        cpu: 300m
        memory: 400Mi

查看qos类型:

bash 复制代码
#查看qos
[root@node-1]# kubectl describe po nginx   | grep QoS
QoS Class:                   Guaranteed

2. Burstable (突发)

当一个 Pod 中至少有一个容器的 requests 小于 limits (即允许资源超额使用)时,该 Pod 被分配为 Burstable 等级:

  • 至少一个容器设置了requests和limits****,但**** requests 小于 limits
  • 其他容器可以只设置 requests 或只设置 limits 。

Burstable 等级的 Pod 允许在资源充足时使用超过 requests 的资源(但不超过 limits ),但在资源紧张时,优先级低于 Guaranteed`,可能会受到影响。

适用场景:

适用于需要灵活使用资源的场景,这些工作负载通常可以容忍一定的资源波动,但仍需要有基本的资源保障。

3. BestEffort (尽力而为)

当一个 Pod 中的所有容器都没有设置 requests 和 limits 时,该 Pod 被分配为 BestEffort` 等级:

  • 所有容器都未设置**requests ****和**** limits

BestEffort 等级的 Pod 没有任何资源保障,在资源争夺时最容易被驱逐,优先级最低。

适用场景:

适用于非关键任务、临时性任务或者对资源需求不确定的应用,如一些辅助性服务或非重要的测试任务。

qos类型是BestEffort测试pod例子,容器必须没有任何内存或者 CPU 的requests 和 limits限制。

bash 复制代码
---
##pod yaml如下:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: nginx
    image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/nginx:stable
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80

查看qos类型:

bash 复制代码
#查看qos
[root@node-1]# kubectl describe po nginx   | grep QoS
QoS Class:                   BestEffort

4. 总结

  • Guaranteed:资源保证度最高,最不容易被驱逐。适用于关键任务应用。
  • Burstable:资源请求小于资源限制,能够在有余量的情况下使用更多资源。适用于需要一定灵活性的应用。
  • BestEffort:没有资源保证,优先级最低,最容易被驱逐。适用于非关键任务应用。

Kubernetes 通过这些 QoS 等级,结合节点上的资源使用情况,智能地调度和管理 Pod 的运行,确保在资源紧张时优先保障关键应用的稳定运行。

相关推荐
yannan201903133 小时前
Docker容器
运维·docker·容器
小宁爱Python4 小时前
Windows Docker Desktop占用C盘空间过大解决办法集合
运维·docker·容器
JAVA学习通4 小时前
发布自己的 jar 包到 Maven 中央仓库 ( mvnrepository.com )
人工智能·docker·自然语言处理·容器·rocketmq
Cloud孙文波4 小时前
探索Apache APISIX:动态高性能API网关
云原生·kubernetes·apisix
木亦汐丫7 小时前
Docker 镜像版本Alpine、Slim、Bookworm、Bullseye、Stretch、Jessie
运维·docker·容器·debian·alpine·slim·bullseye
中草药z9 小时前
【Docker】零基础上手:原理+Ubuntu/Windows GUI 安装 + 镜像源 / 目录优化
运维·ubuntu·docker·容器·gui·安装·cgroups
勇往直前plus10 小时前
如何利用docker部署springboot应用
spring boot·docker·容器
小北爱编程ma11 小时前
【云原生】用Prometheus Operator监听Golang服务指标,并用Granafa可视化展示
云原生
NineData11 小时前
NineData云原生智能数据管理平台新功能发布|2025年9月版
数据库·云原生·devops·ninedata·数据库迁移·数据复制·风险sql管控
博睿谷IT99_12 小时前
Linux 云计算核心技术:原理、组件与 K8s 实战部署
linux·kubernetes·云计算