行業資訊

  • 首頁
  • 新聞中心
  • 行業資訊

兩款好用的 Kubernetes 實時日志查看工具分享給大家


2020年12月16日

通常情況下,Kubernetes 環境下的應用日志都需要通過日志系統來進行收集,比如:Filebeat + ElasticSearch + Kibana 的組合來實現。雖然這一組合的功能相當強大,但是在一些比較簡陋的測試集群中,或者不具備瀏覽器條件的自動化/控制臺環境下,自動合并多個 Pod 中的日志進行集中的查看,對處理問題和調試故障還是很有大幫助的。

今天,我們就給大家介紹兩款超好用的多容器實時日志查看工具 Stern 和 Kubetail。

Stern

Kubectl 本身的 Log 命令是不支持同時查看多個 Pod 容器中的日志,Stern 很好的解決了這個問題, 它除了可以同時 tail 多個容器的日志之外, 還支持以下一些強大的功能:

  • 允許使用正則表達式來選擇需要 tail 的 PodName
  • 自定義不同 Pod 的日志輸出的顏色
  • 自動添加符合規則的新創建 Pod 并進行 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 <search term> [-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 

至此,兩種超實用的多容器實時日志查看工具就介紹完了。如果你還有更好的類似工具推薦,歡迎留言討論


客服
主站蜘蛛池模板: 亚洲人成网站999久久久综合| 色综合久久中文字幕综合网| 人人狠狠综合88综合久久| 亚洲综合图色40p| 99精品国产综合久久久久五月天| 伊伊人成亚洲综合人网7777| 亚洲av日韩综合一区在线观看| 人人狠狠综合久久亚洲88| 天天久久狠狠色综合| 在线综合亚洲中文精品| 亚洲另类激情综合偷自拍| 色婷婷色综合激情国产日韩| 亚洲狠狠综合久久| 亚洲色欲久久久久综合网| 综合色婷婷| 99久久国产综合精品网成人影院| 久久久久综合国产欧美一区二区| 丁香五月网久久综合| 综合在线免费视频| 亚洲VA欧美va国产va综合| 欧美伊人久久大香线蕉综合| 综合激情五月综合激情五月激情1| 99久久亚洲综合精品成人| 激情97综合亚洲色婷婷五| 亚洲人成伊人成综合网久久久| 欧美日韩综合在线| 色天使久久综合网天天| 国产色综合一二三四| 91精品婷婷国产综合久久| 久久天天日天天操综合伊人av| 亚洲欧美精品综合中文字幕| 国产成人综合亚洲亚洲国产第一页| 婷婷色中文字幕综合在线| 亚洲综合激情另类专区| 亚洲综合国产精品第一页| 激情伊人五月天久久综合| 69国产成人综合久久精品| 狠狠色丁香婷综合久久| 婷婷久久综合九色综合绿巨人| 天天做天天爱天天爽综合网| 色噜噜狠狠狠综合曰曰曰|