文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

两款超好用的 Kubernetes 实时日志查看工具

2024-12-03 15:07

关注

通常情况下,Kubernetes 环境下的应用日志都需要通过日志系统来进行收集,比如:Filebeat + ElasticSearch + Kibana 的组合来实现。虽然这一组合的功能相当强大,但是在一些比较简陋的测试集群中,或者不具备浏览器条件的自动化/控制台环境下,自动合并多个 Pod 中的日志进行集中的查看,对处理问题和调试故障还是很有大帮助的。

今天,我们就给大家介绍两款超好用的多容器实时日志查看工具 Stern 和 Kubetail。

Stern

Kubectl 本身的 Log 命令是不支持同时查看多个 Pod 容器中的日志,Stern 很好的解决了这个问题, 它除了可以同时 tail 多个容器的日志之外, 还支持以下一些强大的功能:

项目地址:https://github.com/wercker/stern

安装 Stern

Stern 使用 Go 语言开发,安装非常简单,开箱即用。你只需下载对应平台相关的二进制预编译安装包,就可以使用了。

以 Linux 平台为例:

  1. $ wget https://github.com/wercker/stern/releases/download/1.11.0/stern_linux_amd64 
  2. $ chmod +x stern_linux_amd64 
  3. $ mv stern_linux_amd64 /usr/local/bin 

如果你使用的是 macOS,可以直接 Homebrew 进行安装。

  1. $ brew install stern 

使用 Stern

Stern 支持的功能很多,用法也很丰富。下面我们来看几个比较常用的例子:

实时查看当前 Namespace 中所有 Pod 中所有容器的日志

  1. $ stern  . 

实时查看 Pod 中指定容器的日志

  1. $ stern envvars --container gateway 

实时查看指定命名空间中除指定容器外的所有容器的日志

  1. $ stern -n staging --exclude-container istio-proxy . 

实时查看指定时间范围内容器的日志,下面的例子表示是 15 分钟内

  1. $ stern auth -t --since 15m 

实时查看指定命名空间中容器的日志

  1. $ stern kubernetes-dashboard --namespace kube-system 

实时查看所有命名空间中符合指定标签容器的日志

  1. $ stern --all-namespaces -l run=nginx 

更多用法,可参考「官方文档」。

Kubetail

Kubetail 是一个 Shell 脚本,它可以将多个 Pod 的日志合并到一起,并支持彩色输出。

项目地址:https://github.com/johanhaleby/kubetail

安装 Kubetail

由于 Kubetail 只是一个 Shell 脚本,直接下载后便可使用。

  1. $ wget https://raw.githubusercontent.com/johanhaleby/kubetail/master/kubetail 
  2. $ chmod +x kubetail 
  3. $ cp kubetail /usr/local/bin 

如果你使用的是 macOS,也可以直接 Homebrew 进行安装。

  1. $ brew tap johanhaleby/kubetail && brew install kubetail 

Kubetail 还支持各种 SHELL 管理框架,比如:Oh-my-zsh、Antigen 等,具体安装方法可参考「官方安装文档」。

使用 Kubetail

Kubetail 使用也是非常简单的,基本语法如下:

  1. $ kubetail  [-h] [-c] [-n] [-t] [-l] [-d] [-p] [-s] [-b] [-k] [-v] [-r] [-i]  

一些常用参数的解释:

  1. -c:指定多容器 Pod 中的容器名称 
  2. -t:指定 Kubeconfig 文件中的 Context 
  3. -l:标签过滤器,使用 -l 参数之后,会忽略 Pod 名称 
  4. -n:指定命名空间 
  5. -s:指定返回一个相对时间之后的日志,例如 5s,2m 或者 3h,缺省是 10s 
  6. -b:是否使用 line-buffered,缺省为 false 
  7. -k:指定输出内容的具体着色部分,pod:只给 pod 名称上色,line:整行上色(缺省),false:不上色 

一些使用实例:

  1. $ kubetail my-pod-v1 
  2. $ kubetail my-pod-v1 -c my-container 
  3. $ kubetail my-pod-v1 -t int1-context -c my-container 
  4. $ kubetail '(service|consumer|thing)' -e regex 
  5. $ kubetail -l service=my-service 
  6. $ kubetail --selector service=my-service --since 10m 
  7. $ kubetail --tail 1 

至此,两种超实用的多容器实时日志查看工具就介绍完了。如果你还有更好的类似工具推荐,欢迎留言讨论哟!

参考文档

https://www.google.com

https://zhuanlan.zhihu.com/p/60987559

https://blog.fleeto.us/post/introducing-kubetail/

本文转载自微信公众号「奇妙的Linux世界」,可以通过以下二维码关注。转载本文请联系奇妙的Linux世界公众号。

 

 

来源:奇妙的Linux世界内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯