[英]How to use the kubernetes go-client to get the same Pod status info that kubectl gives
使用 kube.netes go-client ( k8s.io/client-go/kube.netes
),我知道如何获取pod.Status
并且我发现pod.Status.Phase
很有用 ( docs )。 例如,我可以 output 所有 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.Status.Phase
时,处于这些状态的 Pod 仅显示为“Pending”。
Init:0/1
表示 Pod 有 1 个 Init 容器,到目前为止有 0 个已成功完成。 init 容器在应用程序容器启动之前运行。PodInitializing
表示 Pod 已经执行完 Init Container。 有没有办法使用k8s.io/client-go/kube.netes
获得诸如Init:0/1
之类的状态? 还是没有捷径,我需要像 kubectl 一样重新计算它? 我猜它使用 Pod 状态条件和容器状态来构建信息。 如果我需要重新计算它,也许我可以使用kubectl 源代码? 有谁知道我在哪里可以找到相关的位? (我的 golang 经验非常有限)
简短的回答通常是您不必在客户端计算“状态”,因为它是在服务器级别计算的。
为了显示:
您尝试使用kubectl get pods
打印的标准方式,在 Kubernetes 代码库中称为Human Readable 。 此方法使用ServerPrint ,默认为Kubernetes TablePrinter 。 TablePrinter 类型在此处定义。
正如您所看到的,TablePrinter 的PrintObj
函数在此处被委托,但该委托来自于配置 HumanPrintFlags 和保存原始打印机。
此外,您看到在humanreadable_glags.go它包括k8s.io/cli-runtime/pkg/printers
,你看,它的实例化一个printers.NewTablePrinter这是在定义k8s.io/kubernetes/pkg/printers
。
被调用的实际打印函数是这个PrintObj ,您可以看到它处理 3 种情况,因为在某些情况下服务器返回一个表,而有些则不返回(看起来 < 1.16 种情况)。
您还看到,在上述情况下,没有使用https://github.com/kubernetes/kubernetes/tree/master/pkg/printers/internalversion 中的任何代码,因此计算发生在 kube-apiserver 端之后。
请记住,这是人类可读的打印机,这里定义了其他类型的打印机(取决于选项): https : //github.com/kubernetes/kubernetes/tree/master/staging/src/k8s.io/cli -运行时/包装/打印机
我认为你需要重新计算它。 看到这个
我能够显示与kubectl get pods
完全相同的信息。 请在此处查看答案: https://stackoverflow.com/a/74722781/7129053
您应该使用 restClient 来获取原始表输出以表形式接收资源
计算比你想象的要复杂,像Age
字段,在 kubernetes 中,代码: func HumanDuration(d time.Duration) string {...}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.