为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用 kubernetes go-client 获取 kubectl 提供的相同 Pod

如何使用 kubernetes go-client 获取 kubectl 提供的相同 Pod

Go
有只小跳蛙 2023-07-10 14:28:47
使用 kubernetes go-client ( k8s.io/client-go/kubernetes),我知道如何获取pod.Status并且发现pod.Status.Phase有用的 (文档)。例如,我可以使用以下命令输出所有 Pod 的 Pod Status Phase:    ...    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)。我宁愿获得&ldquo;状态&rdquo;kubectl get pods列中提供的相同信息,例如:$ kubectl get podsNAME                                        READY   STATUS              RESTARTS   AGE     IP             NODE                           NOMINATED NODE   READINESS GATESmoby-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 仅显示为&ldquo;待处理&rdquo; pod.Status.Phase。Init:0/1表示 Pod 有 1 个 Init 容器,目前有 0 个已成功完成。init 容器在应用程序容器启动之前运行。PodInitializing表示 Pod 已经执行完 Init Containers。有没有办法获得 Status 例如Init:0/1使用k8s.io/client-go/kubernetes?或者是否没有捷径,我需要像 kubectl 一样重新计算它?我猜它使用 Pod 状态条件和容器状态来构建信息。如果我需要重新计算,也许我可以使用kubectl 源代码?有谁知道我在哪里可以找到相关的位?(我的 golang 经验非常有限)
查看完整描述

4 回答

?
米琪卡哇伊

TA贡献1998条经验 获得超6个赞

简而言之,您通常不必在客户端计算“状态”,因为它是在服务器级别计算的。

为了显示:

在 Kubernetes 代码库中,您尝试使用的标准打印方式kubectl get pods称为“人类可读”。此方法使用ServerPrint,默认为Kubernetes TablePrinter。TablePrinter类型在此定义。

正如您所看到的,PrintObjTablePrinter 的函数在这里被委托。它委托给适当的Kubernetes 资源 PrintObj。此外,该委托还与配置的HumanPrintFlags一起并保存原始打印机。

另外,您会看到在humanreadable_glags.go中它包含k8s.io/cli-runtime/pkg/printers,并且您看到它正在实例化在 中定义的Printers.NewTablePrinterk8s.io/kubernetes/pkg/printers

被调用的实际打印函数是这个PrintObj,您可以看到它处理 3 种情况,因为在某些情况下服务器返回一个表,而另一些则不返回(看起来 < 1.16 种情况)。



查看完整回答
反对 回复 2023-07-10
?
一只萌萌小番薯

TA贡献1795条经验 获得超7个赞

我觉得你需要重新计算一下。


查看完整回答
反对 回复 2023-07-10
?
守着一只汪

TA贡献1872条经验 获得超3个赞

我能够显示与 完全相同的信息kubectl get pods

查看完整回答
反对 回复 2023-07-10
?
慕的地6264312

TA贡献1817条经验 获得超6个赞

您应该使用restClient 获取原始表输出 以表形式接收资源

计算比你想象的要复杂,比如Age字段,在kubernetes中,代码: func HumanDuration(d time.Duration) string {...}


查看完整回答
反对 回复 2023-07-10
  • 4 回答
  • 0 关注
  • 118 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信