任务

Kubernetes v1.12 版本的文档已不再维护。您现在看到的版本来自于一份静态的快照。如需查阅最新文档,请点击 最新版本。

Edit This Page

为命名空间配置 Pod 配额

本文介绍怎样给命名空间配置可以运行的 Pod 总数配额。你在 ResourceQuota对象中可以进行声明。

准备开始

您必须拥有一个 Kubernetes 集群,并且必须使用 kubectl 命令行工具与你的集群进行通信。如果您还没有一个集群,您可以通过 Minikube 创建一个集群,或者使用这些 Kubernetes playground :

To check the version, enter kubectl version.

创建命名空间

创建一个命名空间,以便本练习所创建的资源和集群的其余资源相隔离。

kubectl create namespace quota-pod-example

创建一个 ResourceQuota

这里给出了一个 ResourceQuota 对象的配置文件:

admin/resource/quota-pod.yaml
apiVersion: v1
kind: ResourceQuota
metadata:
  name: pod-demo
spec:
  hard:
    pods: "2"

创建 ResourceQuota

kubectl create -f https://k8s.io/examples/admin/resource/quota-pod.yaml --namespace=quota-pod-example

查看 ResourceQuota 详情:

kubectl get resourcequota pod-demo --namespace=quota-pod-example --output=yaml

输出结果显示该命名空间有两个 Pod 的配额,并且当前没有 Pod;也就是配额没有被使用。

spec:
  hard:
    pods: "2"
status:
  hard:
    pods: "2"
  used:
    pods: "0"

这里给出了一个 Deployment 的配置文件:

admin/resource/quota-pod-deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: pod-quota-demo
spec:
  selector:
    matchLabels:
      purpose: quota-demo
  replicas: 3
  template:
    metadata:
      labels:
        purpose: quota-demo
    spec:
      containers:
      - name: pod-quota-demo
        image: nginx

配置文件中,replicas: 3 使 Kubernetes 尝试创建3个 Pod,都运行相同的应用。

创建 Deployment:

kubectl create -f https://k8s.io/examples/admin/resource/quota-pod-deployment.yaml --namespace=quota-pod-example

查看 Deployment 详情:

kubectl get deployment pod-quota-demo --namespace=quota-pod-example --output=yaml

输出结果显示尽管 Deployment 声明了三个副本,但由于配额的限制只创建了两个 Pod。

spec:
  ...
  replicas: 3
...
status:
  availableReplicas: 2
...
lastUpdateTime: 2017-07-07T20:57:05Z
    message: 'unable to create pods: pods "pod-quota-demo-1650323038-" is forbidden:
      exceeded quota: pod-demo, requested: pods=1, used: pods=2, limited: pods=2'

清理环境

删除你的命名空间:

kubectl delete namespace quota-pod-example

接下来

集群管理员参考

应用开发者参考

反馈