zoukankan      html  css  js  c++  java
  • Kubernetes 服务质量 Qos 解析

    QoS是 Quality of Service 的缩写,即服务质量。为了实现资源被有效调度和分配的同时提高资源利用率,kubernetes针对不同服务质量的预期,通过 QoS(Quality of Service)来对 pod 进行服务质量管理。对于一个 pod 来说,服务质量体现在两个具体的指标:CPU 和内存。当节点上内存资源紧张时,kubernetes 会根据预先设置的不同 QoS 类别进行相应处理。

    QoS 主要分为Guaranteed、Burstable 和 Best-Effort三类,优先级从高到低。

    Guaranteed(有保证的)

    属于该级别的pod有以下两种:

    • Pod中的所有容器都且仅设置了 CPU 和内存的 limits
    • pod中的所有容器都设置了 CPU 和内存的 requests 和 limits ,且单个容器内的requests==limits(requests不等于0)

    pod中的所有容器都且仅设置了limits:

    containers:
      name: foo
        resources:
          limits:
            cpu: 10m
            memory: 1Gi
      name: bar
        resources:
          limits:
            cpu: 100m
            memory: 100Mi

    pod 中的所有容器都设置了 requests 和 limits,且单个容器内的requests==limits

    containers:
      name: foo
        resources:
          limits:
            cpu: 10m
            memory: 1Gi
          requests:
            cpu: 10m
            memory: 1Gi
    
      name: bar
        resources:
          limits:
            cpu: 100m
            memory: 100Mi
          requests:
            cpu: 100m
            memory: 100Mi

    容器foo和bar内resources的requests和limits均相等,该pod的QoS级别属于Guaranteed

    Burstable(不稳定的)

    pod中只要有一个容器的requests和limits的设置不相同,该pod的QoS即为Burstable

    容器foo指定了resource,而容器bar未指定:

    containers:
      name: foo
        resources:
          limits:
            cpu: 10m
            memory: 1Gi
          requests:
            cpu: 10m
            memory: 1Gi
    
      name: bar

    容器foo设置了内存limits,而容器bar设置了CPU limits:

    containers:
      name: foo
        resources:
          limits:
            memory: 1Gi
    
      name: bar
        resources:
          limits:
            cpu: 100m

    注意:若容器指定了requests而未指定limits,则limits的值等于节点resource的最大值;若容器指定了limits而未指定requests,则requests的值等于limits。

    Best-Effort(尽最大努力)

    如果Pod中所有容器的resources均未设置requests与limits,该pod的QoS即为Best-Effort

    容器foo和容器bar均未设置requests和limits:

    containers:
      name: foo
        resources:
      name: bar
        resources:

    根据QoS进行资源回收策略

    Kubernetes 通过cgroup给pod设置QoS级别,当资源不足时先kill优先级低的 pod,在实际使用过程中,通过OOM分数值来实现,OOM分数值范围为0-1000。OOM 分数值根据OOM_ADJ参数计算得出。

    对于Guaranteed级别的 Pod,OOM_ADJ参数设置成了-998,对于Best-Effort级别的 Pod,OOM_ADJ参数设置成了1000,对于Burstable级别的 Pod,OOM_ADJ参数取值从2到999。

    对于 kuberntes 保留资源,比如kubelet,docker,OOM_ADJ参数设置成了-999,表示不会被OOM kill掉。OOM_ADJ参数设置的越大,计算出来的OOM分数越高,表明该pod优先级就越低,当出现资源竞争时会越早被kill掉,对于OOM_ADJ参数是-999的表示kubernetes永远不会因为OOM将其kill掉。

    QoS pods被kill掉场景与顺序

    • Best-Effort pods:系统用完了全部内存时,该类型 pods 会最先被kill掉。
    • Burstable pods:系统用完了全部内存,且没有 Best-Effort 类型的容器可以被 kill 时,该类型的 pods 会被 kill 掉。
    • Guaranteed pods:系统用完了全部内存,且没有 Burstable 与 Best-Effort 类型的容器可以被 kill 时,该类型的 pods 会被 kill 掉。

    QoS使用建议

    如果资源充足,可将 QoS pods 类型均设置为Guaranteed。用计算资源换业务性能和稳定性,减少排查问题时间和成本。如果想更好的提高资源利用率,业务服务可以设置为Guaranteed,而其他服务根据重要程度可分别设置为Burstable或Best-Effort。

  • 相关阅读:
    【第四周】四则运算图形化
    【第四周】【小组项目】【第二次】新蜂小组站会
    【第四周】【小组项目】【第一次】新蜂小组站会
    【第三周】站会和燃尽图
    【第三周】每周psp
    【第三周】四人小组项目
    【第三周】【】cppunit!
    【第二周】【作业一】读构建之法
    【第二周】【作业二】每周例行报告
    词频统计效能测试---------第二版
  • 原文地址:https://www.cnblogs.com/weifeng1463/p/11244530.html
Copyright © 2011-2022 走看看