使用 Kube-capacity CLI 查看 Kubernetes 資源請求、限制和利用率
Kube-capacity
是一個(gè)簡單而強(qiáng)大的CLI
,它提供了Kubernetes
集群中資源請求、限制和利用率的概覽。它將輸出的最佳部分結(jié)合kubectl top
到kubectl describe
一個(gè)易于使用的集中于集群資源的CLI
中。
不過像這樣的工具確實(shí)好用一些,比如我想看這個(gè)kube-system
下有哪些pod
有沒有設(shè)置request
和limit
的時(shí)候,實(shí)際上,我需要輸入一段很長的命令才能列出,而且需要一些調(diào)試,這看起來不是特別方便
#kubectlgetpod-nkube-system-o=custom-columns=NAME:.metadata.name,NAMESPACE:.metadata.namespace,PHASE:.status.phase,Request-cpu:.spec.containers[0].resources.requests.cpu,Request-memory:.spec.containers[0].resources.requests.memory,Limit-cpu:.spec.containers[0].resources.limits.cpu,Limit-memory:.spec.containers[0].resources.limits.memory
NAMENAMESPACEPHASERequest-cpuRequest-memoryLimit-cpuLimit-memory
calico-kube-controllers-7d4c6544cc-g6x6qkube-systemRunning
calico-node-4fjn8kube-systemRunning250m
calico-node-7nbpjkube-systemRunning250m
calico-node-qvdlrkube-systemRunning250m
coredns-7977f69688-4nz9qkube-systemRunning100m70Mi170Mi
coredns-7977f69688-frkt5kube-systemRunning100m70Mi170Mi
etcd-k8s-master1kube-systemRunning100m100Mi
etcd-k8s-master2kube-systemRunning100m100Mi
etcd-k8s-master3kube-systemRunning100m100Mi
kube-apiserver-k8s-master1kube-systemRunning250m
那么這個(gè)工具實(shí)際上解決的問題就是幫助我們快速查看概覽整個(gè)集群和pod
的資源配置情況
安裝
Go
二進(jìn)制文件由GoReleaser
隨每個(gè)版本自動(dòng)構(gòu)建。這些可以在此項(xiàng)目的GitHub
發(fā)布頁面上訪問。
https://github.com/goreleaser/goreleaser
https://github.com/robscott/kube-capacity/releases
Homebrew
這個(gè)項(xiàng)目可以用Homebrew
安裝:
brewtaprobscott/tap
brewinstallrobscott/tap/kube-capacity
Krew
這個(gè)項(xiàng)目可以用Krew
安裝:
kubectlkrewinstallresource-capacity
用法
默認(rèn)情況下,kube-capacity
將輸出一個(gè)節(jié)點(diǎn)列表,其中包含CPU
和內(nèi)存資源請求的總數(shù)以及在它們上運(yùn)行的所有pod
的限制。對(duì)于具有多個(gè)節(jié)點(diǎn)的集群,第一行還將包括集群范圍的總數(shù)。該輸出將如下所示:
包括 Pod
對(duì)于更詳細(xì)的輸出,kube-capacity
可以在輸出中包含pod
。當(dāng)-p
或--pods
被傳遞給kube-capacity
時(shí),它將包含如下所示的特定于pod
的輸出
包括利用率
為了幫助了解資源利用率與配置的請求和限制的比較,kube-capacity
可以在輸出中包含利用率指標(biāo)。請務(wù)必注意,此輸出依賴于集群中的metrics-server
正常運(yùn)行。當(dāng)-u
或--util
被傳遞給kube-capacity
時(shí),它將包含如下所示的資源利用率信息:
包括 Pod 和利用率
對(duì)于更詳細(xì)的輸出,kube-capacity
可以在輸出中包含pod
和資源利用率。當(dāng)--util
和--pods
傳遞給kube-capacity
時(shí),它將產(chǎn)生如下所示的寬輸出:
值得注意的是,來自pod
的利用率數(shù)字可能不會(huì)與總節(jié)點(diǎn)利用率相加。與節(jié)點(diǎn)和集群級(jí)別數(shù)字代表pod
值總和的請求和限制數(shù)字不同,節(jié)點(diǎn)指標(biāo)直接來自指標(biāo)服務(wù)器,并且可能包括其他形式的資源利用率。
排序
要突出顯示具有最高指標(biāo)的節(jié)點(diǎn)、pod
和容器,您可以按各種列進(jìn)行排序:
顯示 Pod 計(jì)數(shù)
要顯示每個(gè)節(jié)點(diǎn)和整個(gè)集群的pod
數(shù)量,可以通過--pod-count
參數(shù):
按標(biāo)簽過濾
對(duì)于更高級(jí)的使用,kube-capacity
還支持按pod
、命名空間和/或節(jié)點(diǎn)標(biāo)簽進(jìn)行過濾。以下示例展示了如何使用這些過濾器:
kube-capacity--pod-labelsapp=nginx
kube-capacity--namespace默認(rèn)
kube-capacity--namespace-labelsteam=api
kube-capacity--node-labelskubernetes.io/role=node
JSON 和 YAML 輸出
默認(rèn)情況下,kube-capacity
將以表格格式提供輸出。要以JSON
或YAML
格式查看此數(shù)據(jù),可以使用輸出標(biāo)志。以下是一些示例命令:
kube-capacity--pods--outputjson
kube-capacity--pods--containers--util--outputyaml
支持的標(biāo)志
先決條件
任何請求集群利用率的命令都依賴于集群上運(yùn)行的metrics-server
。如果尚未安裝,您可以使用官方helm chart
進(jìn)行安裝。
https://github.com/helm/charts/tree/master/stable/metrics-server
https://github.com/kubernetes-incubator/metrics-server
原文標(biāo)題:使用 Kube-capacity CLI 查看 Kubernetes 資源請求、限制和利用率
文章出處:【微信公眾號(hào):馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
-
Capacity
+關(guān)注
關(guān)注
0文章
2瀏覽量
6512 -
CLI
+關(guān)注
關(guān)注
1文章
79瀏覽量
8564 -
kubernetes
+關(guān)注
關(guān)注
0文章
225瀏覽量
8723
原文標(biāo)題:使用 Kube-capacity CLI 查看 Kubernetes 資源請求、限制和利用率
文章出處:【微信號(hào):magedu-Linux,微信公眾號(hào):馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評(píng)論請先 登錄
相關(guān)推薦
評(píng)論