文章來源:云原生實(shí)驗(yàn)室,點(diǎn)擊查看原文
<https://mp.weixin.qq.com/s?__biz=MzU1MzY4NzQ1OA==&mid=2247484203&idx=1&sn=97078722f7f9929afe5258d455c78a76&scene=21#wechat_redirect>
。
導(dǎo)讀:Kubernetes 作為云原生時(shí)代的“操作系統(tǒng)”,熟悉和使用它是每名用戶(User)的必備技能。如果你正在 Kubernetes
上工作,你需要正確的工具和技巧來確保 Kubernetes 集群的高可用以及工作負(fù)載的穩(wěn)定運(yùn)行。本篇文章將為你詳細(xì)介紹 6 個(gè)實(shí)用的 Kubernetes
開源工具,千萬(wàn)不要錯(cuò)過。
前言
隨著 Kubernetes 的發(fā)展和演變,人們可以從內(nèi)部來馴服它的無節(jié)制行為。但有些人并不情愿干等 Kubernetes 變得易于使用,并且為已投入生產(chǎn)的
Kubernetes 中遇到的很多常見問題制定了自己的解決方案。
這里我們將介紹一些提高操作效率的技巧,同時(shí)列舉幾個(gè)比較有用的開源 Kubernetes 工具,這些工具以各種方式簡(jiǎn)化
Kubernetes,包括簡(jiǎn)化命令行交互,簡(jiǎn)化應(yīng)用程序部署語(yǔ)法等。
kubectl 自動(dòng)補(bǔ)全
kubectl?這個(gè)命令行工具非常重要,與之相關(guān)的命令也很多,我們也記不住那么多的命令,而且也會(huì)經(jīng)常寫錯(cuò),所以命令自動(dòng)補(bǔ)全是很有必要的,kubectl
工具本身就支持自動(dòng)補(bǔ)全,只需簡(jiǎn)單設(shè)置一下即可。
bash 用戶
大多數(shù)用戶的 shell 使用的是?bash,Linux 系統(tǒng)可以通過下面的命令來設(shè)置:
$ echo "source <(kubectl completion bash)" >> ~/.bashrc $ source ~/.bashrc
如果發(fā)現(xiàn)不能自動(dòng)補(bǔ)全,可以嘗試安裝?bash-completion?然后刷新即可!
zsh 用戶
如果你使用的 shell 是?zsh,可以通過下面的命令來設(shè)置:
$ echo "source <(kubectl completion zsh)" >> ~/.zshrc $ source ~/.zshrc
自定義 kubectl get 輸出
kubectl get?相關(guān)資源,默認(rèn)輸出為 kubectl 內(nèi)置,一般我們也可以使用?-o json?或者?-o yaml
?查看其完整的資源信息。但是很多時(shí)候,我們需要關(guān)心的信息并不全面,因此我們需要自定義輸出的列,那么可以使用?go-template?來進(jìn)行實(shí)現(xiàn)。
go-template?是 golang 的一種模板,可以參考?template 的相關(guān)說明
<https://golang.org/pkg/text/template/>。
比如僅僅想要查看獲取的 pods 中的各個(gè) pod 的?uid,則可以使用以下命令:
$ kubectl get pods --all-namespaces -o go-template='{{range
.items}}{{.metadata.uid}} {{end}}' 2ea418d4-533e-11e8-b722-005056a1bc83
7178b8bf-4e93-11e8-8175-005056a1bc83 a0341475-5338-11e8-b722-005056a1bc83 ...
因?yàn)?get pods 的返回結(jié)果是?List?類型,獲取的 pods 都在?items?這個(gè)的 value 中,因此需要遍歷 items,也就有了?
{{range .items}}。而后通過模板選定需要展示的內(nèi)容,就是 items 中的每個(gè)?{{.metadata.uid}}。
這里特別注意,要做一個(gè)特別的處理,就是要把?{{end}}?前進(jìn)行換行,以便在模板中插入換行符。
當(dāng)然,如果覺得這樣處理不優(yōu)雅的話,也可以使用?printf?函數(shù),在其中使用?\n?即可實(shí)現(xiàn)換行符的插入。
$ kubectl get pods --all-namespaces -o go-template --template='{{range
.items}}{{printf "%s\n" .metadata.uid}}{{end}}'
或者可以這樣:
$ kubectl get pods --all-namespaces -o go-template --template='{{range
.items}}{{.metadata.uid}}{{"\n"}}{{end}}'
其實(shí)有了?printf,就可以很容易的實(shí)現(xiàn)對(duì)應(yīng)字段的輸出,且樣式可以進(jìn)行自己控制。比如可以這樣:
$ kubectl get pods --all-namespaces -o go-template --template='{{range
.items}}{{printf "|%-20s|%-50s|%-30s|\n" .metadata.namespace .metadata.name
.metadata.uid}}{{end}}' |default |details-v1-64b86cd49-85vks
|2e7a2a66-533e-11e8-b722-005056a1bc83| |default
|productpage-v1-84f77f8747-7tkwb |2eb4e840-533e-11e8-b722-005056a1bc83|
|default |ratings-v1-5f46655b57-qlrxp |2e89f981-533e-11e8-b722-005056a1bc83| ...
下面舉兩個(gè) go-template 高級(jí)用法的例子:
* range 嵌套 # 列出所有容器使用的鏡像名 $ kubectl get pods --all-namespaces -o go-template
--template='{{range .items}}{{range .spec.containers}}{{printf "%s\n"
.image}}{{end}}{{end}}' istio/examples-bookinfo-details-v1:1.5.0
istio/examples-bookinfo-productpage-v1:1.5.0
istio/examples-bookinfo-ratings-v1:1.5.0 ...
* 條件判斷 # 列出所有不可調(diào)度節(jié)點(diǎn)的節(jié)點(diǎn)名與 IP $ kubectl get no -o go-template='{{range
.items}}{{if .spec.unschedulable}}{{.metadata.name}}
{{.spec.externalID}}{{"\n"}}{{end}}{{end}}'
除了使用?go-template?之外,還可以使用逗號(hào)分隔的自定義列列表打印表格:
$ kubectl -n kube-system get pods coredns-64b597b598-7547d -o
custom-columns=NAME:.metadata.name,hostip:.status.hostIP NAME hostip
coredns-64b597b598-7547d 192.168.123.250
也可以使用?go-template-file?自定義模板列表,模板不用通過參數(shù)傳進(jìn)去,而是寫成一個(gè)文件,然后需要指定?template?指向該文件即可。
$ cat > test.tmpl << EOF NAME HOSTIP metadata.name status.hostIP EOF $ kubectl
-n kube-system get pods coredns-64b597b598-7547d -o
custom-columns-file=test.tmpl NAME HOSTIP coredns-64b597b598-7547d
192.168.123.250
交互式 Kubernetes 客戶端
Kube-prompt <https://github.com/c-bata/kube-prompt>?可以讓你在 Kubernetes
客戶端輸入相當(dāng)于交互式命令會(huì)話的東西,并為每個(gè)命令提供自動(dòng)填充的背景信息,你不必鍵入 kubectl 來為每個(gè)命令添加前綴。
生成 kubectl 別名
如果你需要頻繁地使用 kubectl 和 kubernetes api 進(jìn)行交互,使用別名將會(huì)為你節(jié)省大量的時(shí)間,開源項(xiàng)目?kubectl-aliases
<https://github.com/ahmetb/kubectl-aliases>?可以通過編程的方式生成 kubectl 別名,別名生成規(guī)則如下:
*
簡(jiǎn)單別名示例
kd?→?kubectl?describe
*
高級(jí)別名示例
kgdepallw?→?kubectl?get?deployment --all-namespaces --watch
校驗(yàn)配置文件
如果你手動(dòng)寫 Kubernetes manifest 文件,檢查 manifest 文件的語(yǔ)法是很困難的,特別是當(dāng)你有多個(gè)不同版本的 Kubernetes
集群時(shí),確認(rèn)配置文件語(yǔ)法是否正確更是難上加難。
Kubeval <https://github.com/instrumenta/kubeval>?是一個(gè)用于校驗(yàn) Kubernetes YAML 或
JSON 配置文件的工具,支持多個(gè) Kubernetes 版本,可以幫助我們解決不少的麻煩。
* 使用示例 $ kubeval nginx.yaml The document nginx.yaml contains an invalid
Deployment ---> spec.replicas: Invalid type. Expected: integer, given: string
簡(jiǎn)化 Kubernetes 部署定義
很多人都抱怨 Kubernetes manifest 文件的定義太復(fù)雜和冗長(zhǎng)。它們很難寫,而且很難維護(hù),如果能夠簡(jiǎn)化部署定義就會(huì)極大地降低維護(hù)難度。
Kedge <https://mp.weixin.qq.com/s/G8t18WpE_XW69nRmFLZSfg>?提供更簡(jiǎn)單、更簡(jiǎn)潔的語(yǔ)法,然后
kedge 將其轉(zhuǎn)換為 Kubernetes manifest 文件。
* 使用示例
掃描下方二維碼添加小助手,與 8000 位云原生愛好者討論技術(shù)趨勢(shì),實(shí)戰(zhàn)進(jìn)階!
進(jìn)群暗號(hào):公司-崗位-城市
熱門工具 換一換