kibana 查看索引库中文档个数_两款超好用的Kubernetes实时日志查看工具

 58ef03c5b3c4f81d496fc23cf565ef0f.png

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

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

Stern

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

  •  允许使用正则表达式来选择需要 tail 的 PodName
  •  自定义不同 Pod 的日志输出的颜色
  •  自动添加符合规则的新创建 Pod 并进行 tail
  •  ....

项目地址:

安装 Stern

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

以 Linux 平台为例:

$ wget /releases/download/1.11.0/stern_linux_amd64  $ chmod +x stern_linux_amd64  $ mv stern_linux_amd64 /usr/local/bin 

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

$ brew install stern 

使用 Stern

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

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

$ stern  . 

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

$ stern envvars --container gateway 

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

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

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

$ stern auth -t --since 15m 

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

$ stern kubernetes-dashboard --namespace kube-system 

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

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

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

Kubetail

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

项目地址:

安装 Kubetail

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

$ wget   $ chmod +x kubetail  $ cp kubetail /usr/local/bin 

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

$ brew tap johanhaleby/kubetail && brew install kubetail 

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

使用 Kubetail

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

$ kubetail <search term> [-h] [-c] [-n] [-t] [-l] [-d] [-p] [-s] [-b] [-k] [-v] [-r] [-i]  

一些常用参数的解释:

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

一些使用实例:

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

至此,两种超实用的多容器实时日志查看工具就介绍完了。

【编辑推荐】

【责任编辑:

庞桂玉

TEL:(010)68476606】


点赞 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值