QoS(Quality of Service),可译为 “服务质量等级”,或者译作 “服务质量保证”,是作用在 Pod 上的一个配置,当 Kubernetes 创建一个 Pod 时,它就会给这个 Pod 分配一个 QoS 等级。 Kubernetes使用Qos类来决定Pod的调度和驱逐策略。
# cat qos-pod.yaml apiVersion: v1 kind: Pod metadata: name: qos-demo spec: containers: - name: qos-demo-ctr image: nginx resources: limits: memory: "200Mi" cpu: "700m" requests: memory: "200Mi" cpu: "700m" # kubectl apply -f qos-pod.yaml pod/qos-demo created # kubectl describe pod qos-demo | grep QoS QoS Class: Guaranteed
以上可以看出 Kubernetes 为 Pod 配置的 QoS 类为 Guaranteed
如果容器指定了自己的内存限制,但没有指定内存请求,Kubernetes 会自动为它指定与内存限制匹配的内存请求。 同样,如果容器指定了自己的 CPU 限制,但没有指定 CPU 请求,Kubernetes 会自动为它指定与 CPU 限制匹配的 CPU 请求。
# cat qos-pod.yaml apiVersion: v1 kind: Pod metadata: name: qos-demo-2 spec: containers: - name: qos-demo-2-ctr image: nginx resources: limits: memory: "200Mi" requests: memory: "100Mi" # kubectl apply -f qos-pod.yaml pod/qos-demo-2 created # kubectl describe pod qos-demo | grep QoS QoS Class: Burstable
以上可以看出 Kubernetes 为 Pod 配置的 QoS 类为 Burstable
# cat qos-pod.yaml apiVersion: v1 kind: Pod metadata: name: qos-demo-2 spec: containers: - name: qos-demo-2-ctr image: nginx # kubectl apply -f qos-pod.yaml pod/qos-demo-2 created # kubectl describe pod qos-demo | grep QoS QoS Class: BestEffort
QOS是K8S中的一种资源保护机制,其主要是针对不可压缩资源比如内存的一种控制技术。比如在内存中,其通过为不同的Pod和容器构造OOM评分,并且通过内核策略的辅助,从而实现当节点内存资源不足的时候,内核可以按照策略的优先级,优先kill掉那些优先级比较低(分值越高,优先级越低)的Pod。
优先级从高到低排序: