当前位置: 首页 > article >正文

k8s qos等级

QoS(Quality of Service) 简介
QoS(Quality of Service) 简介 QoS(Quality of Service),大部分译为 “服务质量等级”,又译作 “服务质量保证”,是作用在 Pod 上的一个配置,当 Kubernetes 创建一个 Pod 时,它就会给这个 Pod 分配一个 QoS 等级,可以是以下等级之一:

  • Guaranteed
    Pod 里的每个容器都必须有内存/CPU 限制和请求,而且值必须相等。如果一个容器只指明limit而未设定request,则request的值等于limit值。
    如下:
##pod yaml如下:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: spring-k8s
    image: registry-1.ict-mec.net:18443/nginx:latest
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80
    resources:
      limits:       #####requests与limit的值相等
        cpu: 300m
        memory: 400Mi
      requests:
        cpu: 300m
        memory: 400Mi

#查看qos等级
[root@node162 test]# kubectl describe po nginx   | grep QoS
QoS Class:                   Guaranteed
  • Burstable:
    Pod 里至少有一个容器有内存或者 CPU 请求且不满足 Guarantee 等级的要求,即内存/CPU 的值设置的不同。
##pod yaml如下:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: spring-k8s
    image: registry-1.ict-mec.net:18443/nginx:latest
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80
    resources:
      limits:       ###requests与limit的值不相等
        cpu: 300m
        memory: 400Mi
      requests:
        cpu: 200m
        memory: 300Mi

#查看qos等级
[root@node162 test]# kubectl describe po nginx   | grep QoS
QoS Class:                   Burstable
  • BestEffort:
    容器必须没有任何内存或者 CPU 的限制或请求(没有配置资源限制的情况下,默认为 BestEffort。)
###pod  yaml文件如下:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: spring-k8s
    image: registry-1.ict-mec.net:18443/nginx:latest
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80
####查看
[root@node162 ~]# kubectl describe po nginx  | grep -i QoS
QoS Class:                   BestEffort

该配置不是通过一个配置项来配置的,而是通过配置 CPU/MEM的 limitsrequests 值的大小来确认服务质量等级。如果不设,Pod虽然很容易被调度,可以使用整个node资源,但是当资源紧俏时,会被第一个kill。
CPU 在压缩资源部分已经提到CPU属于可压缩资源,当pod使用超过设置的limits值,pod中进程使用cpu会被限制,但不会被kill。
内存 Kubernetes通过cgroup给pod设置QoS级别,当资源不足时先kill优先级低的pod,在实际使用过程中,通过OOM分数值来实现,OOM分数值从0-1000。

OOM分数值根据OOM_ADJ参数计算得出,对于Guaranteed级别的pod,OOM_ADJ参数设置成了-998,对于BestEffort级别的pod,OOM_ADJ参数设置成了1000,对于Burstable级别的POD,OOM_ADJ参数取值从2到999。对于kuberntes保留资源,比如kubelet,docker,OOM_ADJ参数设置成了-999,表示不会被OOM kill掉。OOM_ADJ参数设置的越大,通过OOM_ADJ参数计算出来OOM分数越高,表明该pod优先级就越低,当出现资源竞争时会越早被kill掉,对于OOM_ADJ参数是-999的表示kubernetes永远不会因为OOM而被kill掉。

QoS 优先级
Guaranteed --> Burstable --> BestEffort

Kubernetes 资源回收策略

Kubernetes 资源回收策略:当集群监控到 node 节点内存或者CPU资源耗尽时,为了保护node正常工作,就会启动资源回收策略,通过驱逐节点上Pod来减少资源占用。

这三种策略在由于资源不足而驱逐 Pod 时,有不同的优先级。

BestEffort --> Burstable --> Guaranteed(可以理解先驱逐 BestEffort,再 Burstable,最后是 Guaranteed。)


http://www.kler.cn/a/5850.html

相关文章:

  • 从阿拉伯数字看大端小端字节序
  • FFmpeg Muxer HLS
  • 基于 OPENCV 和 MFC 的图像处理程序
  • ADO.NET知识总结3---SqlCommand命令对象
  • 嵌入式系统 (2.嵌入式硬件系统基础)
  • 深度学习与计算机视觉 (博士)
  • 【Windows版】VScode配置C++开发环境
  • Python实现提前查询考研成绩
  • 大家有没有时候觉得,递归,分治,回溯,傻傻分不清楚?
  • 设计LFU缓存结构(美团面试算法题)
  • 骨传导蓝牙耳机什么牌子,推荐几款比较热销的骨传导耳机
  • 【Elastic (ELK) Stack 实战教程】04、ElasticSearch 集群进阶及优化
  • Java-双向链表的实现
  • 【软件设计师03】数据库系统
  • 电路板焊接技巧实践(没有电烤箱条件下)
  • 人工智能交互革命:探索ChatGPT的无限可能 第13章ChatGPT的应用场景和创新应用
  • 智慧办公抉择之——VBA与Python的选择
  • MySQL尚硅谷学习笔记之DQL语言
  • QT开发笔记(USB Bluetooth)
  • 【新2023Q2模拟题JAVA】华为OD机试 - 快递业务站
  • 使用AXI4总线控制MMCM时钟模块
  • python编程:判断一个数是否是超级素数
  • 解决AJAX在后台使用PHP,ASP,JSP返回数据出现中文乱码的问题
  • 算法训练:贪心与回溯
  • debian 10编译安装gcc 9.5.0
  • 剪枝与重参第一课:修剪结构