【问题标题】:How to use the kubernetes go-client to get the same Pod status info that kubectl gives如何使用 kubernetes go-client 获取与 kubectl 相同的 Pod 状态信息
【发布时间】: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 个值(PendingRunningSucceededFailedUnknown)。我宁愿获得与kubectl get podsStatus 列中提供的相同信息,例如:

$ 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/1PodInitializing 状态感兴趣。处于这些状态的 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 Conditionscontainer statuses 来构建信息。如果我需要重新计算,也许我可以使用the kubectl sourcecode?有谁知道我在哪里可以找到相关位? (我的 golang 经验非常有限)

【问题讨论】:

    标签: go kubernetes kubernetes-go-client


    【解决方案1】:

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

    举例说明:

    您尝试使用kubectl get pods 进行打印的标准方式,在Kubernetes 代码库中称为Human Readable。此方法使用ServerPrint,默认为Kubernetes TablePrinterTablePrinter type is defined here

    如您所见,TablePrinter 的 PrintObj 函数被委派了 here,但该委派来自配置 HumanPrintFlags 并保存原始 printer

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

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

    您还看到,在上述情况下,没有使用 https://github.com/kubernetes/kubernetes/tree/master/pkg/printers/internalversion 中的代码,因此 calculation 发生在 kube-apiserver 端的后面。

    请记住,这是人类可读打印机,此处定义了其他类型的打印机(取决于选项):https://github.com/kubernetes/kubernetes/tree/master/staging/src/k8s.io/cli-runtime/pkg/printers

    【讨论】:

    • 您定义的大部分链接都已损坏。
    • 谢谢,我去看看。东西变了。
    • 更新了链接...好像移动了代码。
    • 如果 Pod 中的所有容器都完成并且 Pod 生命周期变为 COMPLETED,我们如何才能简单地获得通知?任何示例将不胜感激。
    【解决方案2】:

    我认为您需要重新计算它。见this

    【讨论】:

      【解决方案3】:

      您应该使用 restClient 来获取原始表输出 Receiving resources as Tables

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

      【讨论】:

        猜你喜欢
        • 2019-05-20
        • 2020-11-22
        • 2021-08-05
        • 1970-01-01
        • 2021-08-10
        • 2018-11-27
        • 1970-01-01
        • 2019-03-05
        • 2018-10-30
        相关资源
        最近更新 更多