共計 2433 個字符,預(yù)計需要花費 7 分鐘才能閱讀完成。
本篇內(nèi)容主要講解“kubectl 入門知識點有有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓丸趣 TV 小編來帶大家學(xué)習(xí)“kubectl 入門知識點有有哪些”吧!
前言
對 Kubernetes 稍有了解的讀者應(yīng)該都知道聲明式 API 的說法,kubectl 就是一個這種 API 的客戶端,所以 kubectl 的主要功能就是用來操作對象的。
動作
在 kubectl 中被稱為 command 也就是命令。使用 kubectl –help 能看到可用的命令列表:
$ kubectl --help
kubectl controls the Kubernetes cluster manager.
Find more information at: https://kubernetes.io/docs/reference/kubectl/overview/
Basic Commands (Beginner):
create Create a resource from a file or from stdin.
...
run 在集群中運行一個指定的鏡像
...
Basic Commands (Intermediate):
explain 查看資源的文檔
get 顯示一個或更多 resources
...
Deploy Commands:
rollout Manage the rollout of a resource
...
可以看到 kubectl 的命令行幫助非常不錯,不僅有功能說明、分類,還有難度標(biāo)識,甚至有部分的中文說明,kubectl 的每個命令都可以用 –help 查看進一步的幫助說明。
這里列出了很多可用的命令,按照操作能力,主流命令基本可以分為增刪改查(CRUD)四種。
C
新建命令用于在集群中創(chuàng)建對象,最常用的新建命令應(yīng)該是 create、run 了,create 能夠創(chuàng)建多種對象,而 run 則主要用來創(chuàng)建 Pod。這兩個命令都需要在命令行中使用參數(shù)的方式來表達(dá)待創(chuàng)建的對象的字段內(nèi)容,其表達(dá)力非常粗糙和有限,并且?guī)в忻黠@的命令式 API 風(fēng)味,在我的日常工作中已經(jīng)很少用到這樣的命令了。
但是這種命令往往有個妙用,–dry-run=client(舊版本中是 –dry-run),可以在不產(chǎn)生實際操作的情況下,測試命令的輸出,加上 -o yaml,可以幫助輸出 YAML 文檔。
R
get 是最常用的查詢指令,用于獲取對象列表和基本信息,而 describe 則用于獲取一個對象的詳細(xì)信息。另外一個常用的讀取指令就是 Debug 常用的日志查看指令:kubectl logs。
U
最重要的更新命令可以說是 apply,edit 了,patch、label、annotation、scale 等命令也算常用。
apply 是把 yaml 提交給 Kubernetes 集群的最常用方式,而 edit patch 都是用于修改線上負(fù)載的常用手段。label 和 annotation 命令則是用于修改對象元數(shù)據(jù)的,例如標(biāo)簽和注解。
D
這個沒什么好說——delete
獲取幫助
kubectl 的所有命令、子命令都支持 –help 參數(shù),可以用這種方式獲取幫助。
kubectl options 命令能夠獲取 kubectl 的所有全局參數(shù)。
常用參數(shù)
-f:很多指令(不只是 apply 和 create)都可以用 -f 文件名 的方式進行輸入,如果使用管道操作,則可以用參數(shù) -f – 接收 STDIN 的輸入。
-l:可以使用各種對象上的標(biāo)簽對操作范圍進行過濾,例如 -l app=hello
-o:指定輸出格式,這個參數(shù)相對復(fù)雜,最常用的是 yaml 或者 json 用于輸出機器報文,還可以用 JSON Path 或者 Go Template 對結(jié)果進行處理。
對象
對象通常是類型 + 名稱的一個組合,可以用 kubectl 獲得當(dāng)前集群支持的對象類型:
如上圖,輸出內(nèi)容包含幾個列:名稱、簡稱、API 群組、是否歸屬命名空間以及對象的 Kind 屬性。例如常用的 Deployment:
名稱:
Deployment
簡稱:
Deploy
API 群組:
apps
歸屬命名空間:
是
Kind:
Deployment
使用命令 kubectl get deploy,就能獲得當(dāng)前命名空間中的 Deployment 對象列表,如果在尾巴上加入 Deployment 的名稱,就能得到符合名稱要求的 Deployment 對象,
Schema
前面提到的 -f 參數(shù),或者是 get -o yaml,都要用到具體的對象數(shù)據(jù)結(jié)構(gòu),這個結(jié)構(gòu)到底是哪里規(guī)定的呢?基本結(jié)構(gòu)可以分為三個部分,以一個 Namespace 為例:
apiVersion: v1
kind: Namespace
metadata:
name: default
spec:
finalizers:
- kubernetes
一般會分為四個基礎(chǔ)字段:apiVersion、kind、metadata、status 以及 spec。
apiVersion:
格式為 apiGroup / apiVersion,一個對象的 API Group,可以用前文提到的 api-resources 命令查到,而版本則可以通過 kubectl api-versions 查詢得到。
kind:
對應(yīng) api-resources 命令輸出的字段。
metadata:
元數(shù)據(jù),其中包括標(biāo)簽、注解、名稱等字段,如果對象是屬于命名空間的,也會把命名空間寫在這里。
status:
這個字段的內(nèi)容通常是由 Kubenretes 自動填寫的。
經(jīng)常會被省略掉。
spec:
具體的對象內(nèi)容,可以由幾個途徑獲取其定義結(jié)構(gòu)
部分資源可以使用 kubectl explain 對象類別 獲得解釋
如果該資源在集群中有對象存在,可以使用 kubectl get 對象類別 對象名稱 -o yaml 的方式獲得原文,向其致敬。
如果前兩種方法都沒有,就需要去查看 Kubernetes 或者第三方的 API Reference 了。
到此,相信大家對“kubectl 入門知識點有有哪些”有了更深的了解,不妨來實際操作一番吧!這里是丸趣 TV 網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!