【发布时间】:2019-12-09 09:21:15
【问题描述】:
使用 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 在使用 pod.Status.Phase 时只会显示为“Pending”。
-
Init:0/1表示 Pod 有 1 个 Init 容器,到目前为止 0 个已成功完成。 init containers 在应用容器启动之前运行。 -
PodInitializing表示 Pod 已经执行完 Init Containers。
有没有办法使用k8s.io/client-go/kubernetes 获得Init:0/1 之类的状态?还是没有捷径,我需要像 kubectl 一样重新计算它?我猜它使用 Pod Status Conditions 和 container statuses 来构建信息。如果我需要重新计算,也许我可以使用the kubectl sourcecode?有谁知道我在哪里可以找到相关位? (我的 golang 经验非常有限)
【问题讨论】:
标签: go kubernetes kubernetes-go-client