作者信息:https://home.cnblogs.com/u/huangjiabobk

在k8S中,QoS作用是什么?

在Kubernetes(k8s)中,QoS(Quality of Service,服务质量)是一种资源管理策略,它通过评估Pod对CPU和内存资源的需求与限制来决定在资源紧张时如何优先分配资源。QoS确保集群在面临资源竞争时能够公平地处理不同类型的Pod,并尽可能维持系统的稳定性和响应性。

Kubernetes根据Pod的资源配置将其分为三个QoS级别:

  1. Guaranteed

    • 当Pod中的每个容器都设置了内存和CPU请求(requests)和限制(limits),且两者相等时,该Pod会被赋予Guaranteed QoS等级。
    • Kubernetes会尽力保证这类Pod获得其请求的资源,并在系统资源不足时尽量不牺牲这些Pod的运行性能。
  2. Burstable

    • 如果Pod至少有一个容器设置了资源请求并且请求量小于限制量,或者资源请求未完全设置,那么该Pod会被视为Burstable级别。
    • 这类Pod在资源充足时可以使用超过其请求量的资源,但在资源紧张时,系统可能会减少它们超出请求部分的资源分配。
  3. BestEffort

    • 对于既没有设置内存或CPU请求也没有设置限制的Pod,将被自动归为BestEffort级别。
    • 这些Pod无法获得任何资源保障,当系统资源紧张时,它们最有可能被首先剥夺资源,甚至可能被系统终止以释放资源给其他更重要的Pod。

综上所述,QoS机制允许Kubernetes调度器和kubelet节点代理基于Pod的QoS级别,在必要时做出智能决策,以保持集群整体的稳定性和关键服务的高可用性。尤其在集群接近满负荷运作时,QoS对于避免资源争夺和防止重要应用因资源不足而性能下降至关重要。

posted @ 2024-02-18 10:20  黄嘉波  阅读(118)  评论(0编辑  收藏  举报
版权声明:原创作品,谢绝转载!否则将追究法律责任。--作者 黄嘉波