quota


weight: 77 title:管理namespace中的资源配额 date: ‘2022-05-21T00:00:00+08:00’ type: book

当用多个团队或者用户共用同一个集群的时候难免会有资源竞争的情况发生,这时候就需要对不同团队或用户的资源使用配额做出限制。

开启资源配额限制功能

目前有两种资源分配管理相关的控制策略插件 ResourceQuotaLimitRange

要启用它们只要API Server的启动配置的 KUBE_ADMISSION_CONTROL 参数中加入了 ResourceQuota 的设置,这样就给集群开启了资源配额限制功能,加入 LimitRange 可以用来限制一个资源申请的范围限制,参考 namesapce配置默认的内存请求与限额namespace中配置默认的CPU请求与限额

两种控制策略的作用范围都是对于某一namespaceResourceQuota 用来限制namespace中所有的Pod占用的总的资源requestlimit,而 LimitRange 是用来设置namespacePod的默认的资源requestlimit值。

资源配额分为三种类型:

  • 计算资源配额
  • 存储资源配额
  • 对象数量配额

关于资源配额的详细信息请参考Kubernetes官方文档 资源配额

示例

我们为 spark-cluster 这个namespace设置 ResouceQuotaLimitRange

以下yaml文件可以在 kubernetes-handbookmanifests/spark-with-kubernetes-native-scheduler 目录下找到。

配置计算资源配额

配置文件:spark-compute-resources.yaml

apiVersion: v1
kind: ResourceQuota
metadata:
  name: compute-resources
  namespace: spark-cluster
spec:
  hard:
    pods: "20"
    requests.cpu: "20"
    requests.memory: 100Gi
    limits.cpu: "40"
    limits.memory: 200Gi

要想查看该配置只要执行:

kubectl -n spark-cluster describe resourcequota compute-resources

配置对象数量限制

配置文件:spark-object-counts.yaml

apiVersion: v1
kind: ResourceQuota
metadata:
  name: object-counts
  namespace: spark-cluster
spec:
  hard:
    configmaps: "10"
    persistentvolumeclaims: "4"
    replicationcontrollers: "20"
    secrets: "10"
    services: "10"
    services.loadbalancers: "2"

配置CPU和内存LimitRange

配置文件:spark-limit-range.yaml

apiVersion: v1
kind: LimitRange
metadata:
  name: mem-limit-range
spec:
  limits:
  - default:
      memory: 50Gi
      cpu: 5
    defaultRequest:
      memory: 1Gi
      cpu: 1
    type: Container
  • defaultlimit的值
  • defaultRequestrequest的值

参考

上一页
下一页