Redian新闻
>
关于K8S的服务质量QoS你知道多少?

关于K8S的服务质量QoS你知道多少?

公众号新闻

一、K8S中的应用服务质量(QoS)

服务质量(QoS)类是Kubernetes的概念,它确定Pod的调度和驱逐优先级

Kubelet使用它来管理驱逐pod的顺序,以及使用高级CPU管理策略允许更复杂的pod调度决策。

QoS由Kubernetes本身分配给Pod。但是,DevOps可以通过处理Pod内各个容器的资源请求和限制来控制分配给容器的QoS类。

二、QoS级别

  • Guaranteed:POD中所有容器(包含初始化容器)都必须统一设置了limits,并且设置参数都一致;

  • Burstable:POD中有容器设置了 内存 或 CPU request;

  • BestEffort:POD中的所有容器都没有指定CPU和内存的requests和limits;

2.1、Guaranteed

对于 QoS 类为 Guaranteed 的 Pod:

  • Pod 中的每个容器,包含初始化容器,必须指定内存 请求和 内存 限制,并且两者要相等。

  • Pod 中的每个容器,包含初始化容器,必须指定 CPU 请求和 CPU 限制,并且两者要相等。

apiVersion: v1
kind: Pod
metadata:
name: qos-demo
spec:
containers:
- name: qos-demo
  image: nginx
  resources:
    limits:
      memory: "500Mi"
      cpu: "700m"
    requests:
      memory: "500Mi"
      cpu: "700m"

验证:

# kubectl describe po qos-demo
···
QoS Class:                   Guaranteed

注意点:

如果容器指定了自己的内存limits,但没有指定内存requests,Kubernetes 会自动为它指定与内存limits匹配的内存requests。同样,如果容器指定了自己的 CPU limits,但没有指定 CPU requests,Kubernetes 会自动为它指定与 CPU limits匹配的 CPU requests;

2.2、Burstable

如果满足下面条件,将会指定 Pod 的 QoS 类为 Burstable:

  • Pod 不符合 Guaranteed QoS 类的标准;

  • Pod 中至少一个容器具有内存 CPU requests;

apiVersion: v1
kind: Pod
metadata:
name: qos-demo2
spec:
containers:
- name: qos-demo2
  image: nginx
  resources:
    limits:
      memory: "500Mi"
    requests:
      memory: "200Mi"

验证:

# kubectl describe po qos-demo2
···
QoS Class:                   Burstable

2.3、BestEffort

对于 QoS 类为 BestEffort 的 Pod,Pod 中的容器必须没有设置内存和 CPU 限制或请求。

apiVersion: v1
kind: Pod
metadata:
name: qos-demo3
spec:
containers:
- name: qos-demo3
  image: nginx

三、QoS优先级

3种QoS优先级从有低到高(从左向右):

BestEffort pods -> Burstable pods -> Guaranteed pods

四、驱逐原理

可压缩资源:CPU

在压缩资源部分已经提到CPU属于可压缩资源,当pod使用超过设置的limits值,pod中进程使用cpu会被限制,但不会被kill。

不可压缩资源:内存

4.1、节点OOM时如何处理Guaranteed, Burstable 和 BestEffort Pods?

如果节点在Kubelet可以回收之前耗尽了内存,即节点发生了oom,则oom_killer会根据其oom_score终止容器。

对于 “Guaranteed” Pod中的容器,oom_score_adj 为 “ -998”;

对于 “BestEffort” Pod中的容器,其为“ 1000”;

Burstable Pod中的容器,值为“ min(max(2,1000-(1000 * memoryRequestBytes)/ machineMemoryCapacityBytes),999” )”。

oom_killer首先终止QoS等级最低,且超过请求资源最多的容器。这意味着会优先从Burstable中选择占用资源请求过多的容器进行驱逐;

五、最佳实践

  • 1、按照应用类型进行分类:核心应用(core)/ 常规应用(nomarl)/ 附加应用(extral)

  • 2、核心应用:Guaranteed  / 常规应用:Burstable / 附加应用:BestEffort

  • 3、集群节点分为:核心应用节点 / 常规应用节点 / 附加应用节点

  • 4、调度策略:

    • 核心应用:可以采用nodeAffinity的prefer调度策略调度到核心节点;

    • 常规应用:可以采用nodeAffinity的硬亲和调度策略调度到常规节点;

    • 附加应用:可以采用nodeAffinity的硬亲和调度策略调度到附加节点;

链接:https://blog.51cto.com/u_12593421/6288890

(版权归原作者所有,侵删)


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
3个管理多k8s集群实用工具K8s 弃用 Docker!一文介绍 containerd ctr、crictl 使用关于床上的“冷知识”,你知道多少?你一定不知道,这4个关于KIT的冷知识!iQOO 11S/红魔8S Pro系列发布;苹果客服回应文案被指三观不正从内核角度理解K8s CPU限流的原理九剑一魂 - 第23回 太子遇害 贾后伏诛(九)奥拉氟 vs 普通氟,儿童牙膏的那些“门道”你知道多少?炎炎夏天催生防晒经济,和“防晒”有关的英语你知道多少?字节跳动开源KubeAdmiral:基于 K8s 的新一代多集群编排调度引擎不是我一事无成,而是我无可奈何!美本孩子的苦,家长知道多少?K8S之长连接负载均衡问题澳洲Lifeline逾两成求助电话未接听!服务质量严重堪忧【金融行业】交易商协会发布《关于进一步提升债务融资工具融资服务质效有关事项的通知》—监管政策周报让K8s更加高效:服务暴露和Ingress七层代理的最佳实践!爱晒衣服的日本人如何高效定位故障?这款 K8s 日志查看神器有多香?彻底告别K8s和Docker Swarm!Ruby On Rails 之父下云后:系统好用又便宜,还清理了几千行代码衣食住行背后的历史学问,你知道多少?上云价值倒挂严重,1年云支出高达320万美元,这家公司彻底去云、放弃K8s意外地好!!!!!Microsoft 必应图像创建者从业务出发,K8S环境自建和非自建整体架构设计比较K8S 之长连接负载均衡问题这个开源工具防止错误配置乱入k8s生产环境k8s竟如此简单?大牛总结最佳路线实践!深入探究K8s的安全配置资源Secret!基于go语言的k8s二次开发部署关键业务服务保证技术QoS理论和实践开源世界的两巨头:Linux和k8s结合|招聘岗位平均月薪3万+?如何逐步安装 Kubernetes(k8s)指标服务器 | Linux 中国K8S很难吗?带你从头到尾捋一遍,不信你学不会!斜风细雨不须归“我最后悔的事,面试Freshfields的前2个小时,没有看UBS的新闻”就这么往卧室里一放,不知道多少人要嫉妒我~长篇小说《如絮》第一百零三章 哈尔滨-1952-1953年 2 任务
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。