任务

Edit This Page

为命名空间配置 Pod 配额

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

准备开始

你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 Minikube 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

为了检查版本, 输入 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

接下来

集群管理员参考

应用开发者参考

反馈