使用 kubernetes go-client ( k8s.io/client-go/kubernetes
),我知道如何获取pod.Status
并且发现pod.Status.Phase
有用 ( docs )。例如,我可以使用以下命令输出所有 Pod 的 Pod 状态阶段:
...
api := clientset.CoreV1()
pods, err := api.Pods("").List(metav1.ListOptions{})
for i, pod := range pods.Items {
podstatusPhase := string(pod.Status.Phase)
podCreationTime := pod.GetCreationTimestamp()
age := time.Since(podCreationTime.Time).Round(time.Second)
podInfo := fmt.Sprintf("[%d] Pod: %s, Phase: %s , Created: %s, Age: %s", i, pod.GetName(), podstatusPhase, podCreationTime, age.String())
fmt.Println(podInfo)
}
但是,phase
它有点简单,因为它只显示 5 个值(Pending
、Running
、Succeeded
、Failed
、Unknown
)。我宁愿获得与kubectl get pods
Status 列中相同的信息,例如:
$ kubectl get pods
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
moby-dick-cron-scheduler-1564578660-bg4sb 0/2 ContainerCreating 0 178m <none> ip-10-30-13-151.ec2.internal <none> <none>
notifications-missed-calls-1564564740-js762 0/2 Init:0/1 0 6h49m <none> ip-10-30-13-6.ec2.internal <none> <none>
antivirus-scanner-cron-1564576740-sd6hh 0/2 Completed 0 3h30m 10.30.13.169 ip-10-30-13-151.ec2.internal <none> <none>
Init:0/1
特别是,我对PodInitializing
状态感兴趣。处于这些状态的 Pod 在使用 时只会显示为“Pending” pod.Status.Phase
。
Init:0/1
表示 Pod 有 1 个 Init 容器,到目前为止 0 个已成功完成。init 容器在应用容器启动之前运行。PodInitializing
表示 Pod 已经完成了 Init Containers 的执行。
有没有办法获得状态,例如Init:0/1
using k8s.io/client-go/kubernetes
?还是没有捷径,我需要像 kubectl 一样重新计算它?我猜它使用 Pod 状态条件和容器状态来构建信息。如果我需要重新计算它,也许我可以使用kubectl 源代码?有谁知道我在哪里可以找到相关位?(我的golang经验非常有限)