-
互聯(lián)網(wǎng)安全法,互聯(lián)網(wǎng)凈網(wǎng)行動
-
”凈網(wǎng)2020”落實(shí)好維護(hù)網(wǎng)絡(luò)安全責(zé)任
-
關(guān)于端午節(jié)放假通知-宇眾網(wǎng)絡(luò)
-
宇眾網(wǎng)絡(luò)春節(jié)放假通知
-
關(guān)于公司收款銀行賬戶變更通知函-宇眾網(wǎng)絡(luò)
-
關(guān)于網(wǎng)上有人冒充我公司名義進(jìn)行詐騙的公告。
-
關(guān)于端午節(jié)放假通知,節(jié)日放假,但是我們業(yè)務(wù)不“放假”-宇眾網(wǎng)絡(luò)
-
工信部進(jìn)一步加強(qiáng)未備案網(wǎng)站管理工作的通知-宇眾網(wǎng)絡(luò)
-
關(guān)于東莞市宇眾網(wǎng)絡(luò)科技有限公司香港數(shù)據(jù)中心(香港機(jī)房)路由優(yōu)化通知
-
宇眾網(wǎng)絡(luò)慶祝五·一勞動節(jié)快樂
-
東莞東城機(jī)房網(wǎng)絡(luò)升級通知
-
臨近過年,互聯(lián)網(wǎng)IDC貴圈也有被騙的,請認(rèn)準(zhǔn)宇眾網(wǎng)絡(luò)公司官方聯(lián)系方式
-
我司已獲得ISP/ICP/IDC三證資格,更好的為客戶服務(wù)
-
關(guān)于浙江金華高防機(jī)房網(wǎng)絡(luò)線路切割通知
-
工信部近日下發(fā)關(guān)于進(jìn)一步規(guī)范域名備案工作的通知
行業(yè)資訊
- 首頁
- 新聞中心
- 行業(yè)資訊
兩款好用的 Kubernetes 實(shí)時日志查看工具分享給大家
通常情況下,Kubernetes 環(huán)境下的應(yīng)用日志都需要通過日志系統(tǒng)來進(jìn)行收集,比如:Filebeat + ElasticSearch + Kibana 的組合來實(shí)現(xiàn)。雖然這一組合的功能相當(dāng)強(qiáng)大,但是在一些比較簡陋的測試集群中,或者不具備瀏覽器條件的自動化/控制臺環(huán)境下,自動合并多個 Pod 中的日志進(jìn)行集中的查看,對處理問題和調(diào)試故障還是很有大幫助的。
今天,我們就給大家介紹兩款超好用的多容器實(shí)時日志查看工具 Stern 和 Kubetail。
Stern
Kubectl 本身的 Log 命令是不支持同時查看多個 Pod 容器中的日志,Stern 很好的解決了這個問題, 它除了可以同時 tail 多個容器的日志之外, 還支持以下一些強(qiáng)大的功能:
- 允許使用正則表達(dá)式來選擇需要 tail 的 PodName
- 自定義不同 Pod 的日志輸出的顏色
- 自動添加符合規(guī)則的新創(chuàng)建 Pod 并進(jìn)行 tail
- ....
項(xiàng)目地址:https://github.com/wercker/stern
安裝 Stern
Stern 使用 Go 語言開發(fā),安裝非常簡單,開箱即用。你只需下載對應(yīng)平臺相關(guān)的二進(jìn)制預(yù)編譯安裝包,就可以使用了。
以 Linux 平臺為例:
- $ wget https://github.com/wercker/stern/releases/download/1.11.0/stern_linux_amd64
- $ chmod +x stern_linux_amd64
- $ mv stern_linux_amd64 /usr/local/bin
如果你使用的是 macOS,可以直接 Homebrew 進(jìn)行安裝。
- $ brew install stern
使用 Stern
Stern 支持的功能很多,用法也很豐富。下面我們來看幾個比較常用的例子:
實(shí)時查看當(dāng)前 Namespace 中所有 Pod 中所有容器的日志
- $ stern .
實(shí)時查看 Pod 中指定容器的日志
- $ stern envvars --container gateway
實(shí)時查看指定命名空間中除指定容器外的所有容器的日志
- $ stern -n staging --exclude-container istio-proxy .
實(shí)時查看指定時間范圍內(nèi)容器的日志,下面的例子表示是 15 分鐘內(nèi)
- $ stern auth -t --since 15m
實(shí)時查看指定命名空間中容器的日志
- $ stern kubernetes-dashboard --namespace kube-system
實(shí)時查看所有命名空間中符合指定標(biāo)簽容器的日志
- $ stern --all-namespaces -l run=nginx
更多用法,可參考「官方文檔」。
Kubetail
Kubetail 是一個 Shell 腳本,它可以將多個 Pod 的日志合并到一起,并支持彩色輸出。
項(xiàng)目地址:https://github.com/johanhaleby/kubetail
安裝 Kubetail
由于 Kubetail 只是一個 Shell 腳本,直接下載后便可使用。
- $ wget https://raw.githubusercontent.com/johanhaleby/kubetail/master/kubetail
- $ chmod +x kubetail
- $ cp kubetail /usr/local/bin
如果你使用的是 macOS,也可以直接 Homebrew 進(jìn)行安裝。
- $ 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]
一些常用參數(shù)的解釋:
- -c:指定多容器 Pod 中的容器名稱
- -t:指定 Kubeconfig 文件中的 Context
- -l:標(biāo)簽過濾器,使用 -l 參數(shù)之后,會忽略 Pod 名稱
- -n:指定命名空間
- -s:指定返回一個相對時間之后的日志,例如 5s,2m 或者 3h,缺省是 10s
- -b:是否使用 line-buffered,缺省為 false
- -k:指定輸出內(nèi)容的具體著色部分,pod:只給 pod 名稱上色,line:整行上色(缺?。?,false:不上色
一些使用實(shí)例:
- $ 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
至此,兩種超實(shí)用的多容器實(shí)時日志查看工具就介紹完了。如果你還有更好的類似工具推薦,歡迎留言討論