返回顶部
首页 > 资讯 > 后端开发 > GO >如何使用 kubernetes go-client 获取 kubectl 提供的相同 Pod 状态信息
  • 187
分享到

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

2024-04-05 00:04:05 187人浏览 八月长安
摘要

“纵有疾风来,人生不言弃”,这句话送给正在学习golang的朋友们,也希望在阅读本文《如何使用 kubernetes Go-client 获取 kubectl 提供的相同 Pod 状态信息》后,能够

“纵有疾风来,人生不言弃”,这句话送给正在学习golang的朋友们,也希望在阅读本文《如何使用 kubernetes Go-client 获取 kubectl 提供的相同 Pod 状态信息》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

问题内容

使用 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 个值(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.status.phase 时,处于这些状态的 pod 仅显示为“待处理”。

  • init:0/1 表示 pod 有 1 个 init 容器,目前有 0 个已成功完成。 init 容器在应用容器启动之前运行。
  • podinitializing 表示 pod 已经执行完 init containers。

有没有办法使用 k8s.io/client-go/kubernetes 获取诸如 init:0/1 之类的状态?或者是否没有捷径,我需要像 kubectl 一样重新计算它?我猜它使用 pod 状态条件和容器状态来构建信息。如果我需要重新计算,也许我可以使用 kubectl 源代码?有谁知道我在哪里可以找到相关的位? (我的 golang 经验非常有限)


解决方案


我能够显示与 kubectl get pods 完全相同的信息。请在此处查看答案:https://stackoverflow.com/a/74722781/7129053

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

举例说明:

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

正如您所看到的,TablePrinter 的 PrintObj 函数被委托为 here。它委托给相应的 Kubernetes resource PrintObj。此外,该委托与配置的 HumanPrintFlags 一起并保存原始的 printer。

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

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

您还可以看到,在上述情况下,Https://GitHub.com/kubernetes/kubernetes/tree/4477bf02f211093b32cf58f64aa42aff77daea61/pkg/printers/internalversion 中的代码均未使用,因此 calculation 发生在 kube-apiserver 端后面。

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

理论要掌握,实操不能落!以上关于《如何使用 kubernetes go-client 获取 kubectl 提供的相同 Pod 状态信息》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注编程网公众号吧!

您可能感兴趣的文档:

--结束END--

本文标题: 如何使用 kubernetes go-client 获取 kubectl 提供的相同 Pod 状态信息

本文链接: https://lsjlt.com/news/596405.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作