我正在尝试在 Kubernetes 上自动扩展我的 StatefulSet。为此,我需要获取当前的 pod 数量。
处理部署时:
kubectl describe deployments [deployment-name] | grep desired | awk '{print $2}' | head -n1
这将输出一个数字,即当前部署的数量。
但是,当您运行时
kubectl describe statefulsets
我们没有得到那么多信息。知道如何获取有状态集的当前副本数吗?
kubectl get sts web -n default -o=jsonpath='{.status.replicas}'
这也适用于 .status.readyReplicas 和 .status.currentReplicas
从 github.com/kubernetes:
副本是 StatefulSet 控制器创建的 Pod 数量。
副本 int32readyReplicas 是由 StatefulSet 控制器创建的具有 Ready 条件的 Pod 的数量。
ReadyReplicas int32currentReplicas 是 StatefulSet 控制器从 StatefulSet 版本
创建的 Pod 数量 表示由 当前修订版。
当前副本 int32
您应该运行以下命令之一
master $ kubectl get statefulsets
NAME DESIRED CURRENT AGE
web 4 4 2m
master $
master $ kubectl get sts
NAME DESIRED CURRENT AGE
web 4 4 2m
number of running pods
---------------------
master $ kubectl describe sts web|grep Status
Pods Status: 4 Running / 0 Waiting / 0 Succeeded / 0 Failed
another way
------------
master $ kubectl get sts --show-labels
NAME DESIRED CURRENT AGE LABELS
web 4 4 33s app=nginx
master $ kubectl get po -l app=nginx
NAME READY STATUS RESTARTS AGE
web-0 1/1 Running 0 56s
web-1 1/1 Running 0 55s
web-2 1/1 Running 0 30s
web-3 1/1 Running 0 29s
master $ kubectl get po -l app=nginx --no-headers
web-0 1/1 Running 0 2m
web-1 1/1 Running 0 2m
web-2 1/1 Running 0 1m
web-3 1/1 Running 0 1m
master $
master $
master $ kubectl get po -l app=nginx --no-headers | wc -l
4