配置命名空间下pod总数

本文主要描述如何配置一个命名空间下可运行的pod总数。资源配额详细信息可查看:资源配额

准备开始

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

要获知版本信息,请输入 kubectl version.

创建一个命名空间

首先创建一个命名空间,这样可以将本次操作中创建的资源与集群其他资源隔离开来。

  1. kubectl create namespace quota-pod-example

创建资源配额

下面是一个资源配额的配置文件:

admin/resource/quota-pod.yaml 配置命名空间下pod总数 - 图1
  1. apiVersion: v1
  2. kind: ResourceQuota
  3. metadata:
  4. name: pod-demo
  5. spec:
  6. hard:
  7. pods: 2

创建这个资源配额:

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

查看资源配额的详细信息:

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

从输出的信息我们可以看到,该命名空间下pod的配额是2个,目前创建的pods数为0,配额使用率为0。

  1. spec:
  2. hard:
  3. pods: "2"
  4. status:
  5. hard:
  6. pods: "2"
  7. used:
  8. pods: "0"

下面是一个Deployment的配置文件:

admin/resource/quota-pod-deployment.yaml 配置命名空间下pod总数 - 图2
  1. apiVersion: apps/v1
  2. kind: Deployment
  3. metadata:
  4. name: pod-quota-demo
  5. spec:
  6. selector:
  7. matchLabels:
  8. purpose: quota-demo
  9. replicas: 3
  10. template:
  11. metadata:
  12. labels:
  13. purpose: quota-demo
  14. spec:
  15. containers:
  16. - name: pod-quota-demo
  17. image: nginx

在配置文件中, replicas: 3 告诉kubernetes尝试创建三个pods,且运行相同的应用。

创建这个Deployment:

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

查看Deployment的详细信息:

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

从输出的信息我们可以看到,尽管尝试创建三个pod,但是由于配额的限制,只有两个pod能被成功创建。

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

清理

删除命名空间:

  1. kubectl delete namespace quota-pod-example

接下来

对于集群管理

对于应用开发