網(wǎng)站首頁 編程語言 正文
kubectl概述
Kubectl是一個(gè)命令行界面,用于運(yùn)行針對Kubernetes集群的命令。Kubectl的配置文件在$HOME/.kube目錄。我們可以通過設(shè)置KUBECONFIG環(huán)境變量或設(shè)置命令參數(shù)--kubeconfig來指定其他位置的kubeconfig文件。
kubectl語法
1.使用以下語法kubectl從終端窗口運(yùn)行命令:
kubectl [command] [TYPE] [NAME] [flags]
2.其中command,TYPE,NAME,和flags分別是:
- command
指定要在一個(gè)或多個(gè)資源進(jìn)行的操作,例如create,get,describe,delete。例如“kubectl get cs”。
- TYPE
指定資源類型。資源類型不區(qū)分大小寫,可以指定單數(shù),復(fù)數(shù)或縮寫形式。
范例:
#以下命令產(chǎn)生相同的輸出
kubectl get pod pod1
kubectl get pods pod1
kubectl get po pod1
- NAME
指定資源的名稱。名稱區(qū)分大小寫。如果省略名稱,則顯示所有資源的詳細(xì)信息,如“kubectl get pods”。
在對多個(gè)資源執(zhí)行操作時(shí),我們可以按類型和名稱指定每個(gè)資源,或指定一個(gè)或多個(gè)文件:
1.要按類型和名稱指定資源:
- 如果資源類型相同,則對資源進(jìn)行分組:
TYPE1 name1 name2 name<#>。
范例:
kubectl get pod example-pod1 example-pod2
- 分別指定多種資源類型:
TYPE1/name1 TYPE1/name2 TYPE2/name3 TYPE<#>/name<#>。
范例:
kubectl get pod/example-pod1 replicationcontroller/example-rc1
2.要使用一個(gè)或多個(gè)文件指定資源:
-f file1 -f file2 -f file<#>
#注意使用YAML而不是JSON,因?yàn)閅AML往往更加用戶友好,特別是對于配置文件。
范例:
kubectl get pod -f ./pod.yaml
- flags:
指定的可選標(biāo)志,不過值得注意的是,使用命令行指定參數(shù)會覆蓋默認(rèn)值以及相關(guān)的環(huán)境變量。
例如,我們可以使用-s或--server標(biāo)志來指定Kubernetes API服務(wù)器的地址和端口。
kubectl管理命令
類型 | 命令 | 描述 |
---|---|---|
基礎(chǔ)命令 | create | 通過文件名或標(biāo)準(zhǔn)輸入創(chuàng)建資源 |
expose | 將一個(gè)資源公開為一個(gè)新的Service | |
run | 在集群中運(yùn)行一個(gè)特定的鏡像 | |
set | 在對象上設(shè)置特定的功能 | |
get | 顯示一個(gè)或多個(gè)資源 | |
explain | 文檔參考資料 | |
edit | 使用默認(rèn)的編輯器編輯一個(gè)資源 | |
delete | 通過文件名、標(biāo)準(zhǔn)輸入、資源名稱或標(biāo)簽選擇器來刪除資源 | |
部署命令 | rollout | 管理資源的發(fā)布 |
rolling-update | 對給定的復(fù)制控制器滾動更新 | |
scale | 擴(kuò)容或縮容Pod數(shù)量,Deployment、ReplicaSet、RC或Job | |
autoscale | 創(chuàng)建一個(gè)自動選擇擴(kuò)容或縮容并設(shè)置Pod數(shù)量 | |
集群管理命令 | certificate | 修改證書資源 |
cluster-info | 顯示集群信息 | |
top | 顯示資源(CPU/Memory/Storage)使用。需要Heapster運(yùn)行 | |
cordon | 標(biāo)記節(jié)點(diǎn)不可調(diào)度 | |
uncordon | 標(biāo)記節(jié)點(diǎn)可調(diào)度 | |
drain | 驅(qū)逐節(jié)點(diǎn)上的應(yīng)用,準(zhǔn)備下線維護(hù) | |
taint | 修改節(jié)點(diǎn)taint標(biāo)記 | |
調(diào)試命令 | describe | 顯示特定資源或資源組的詳細(xì)信息 |
logs | 在一個(gè)Pod中打印一個(gè)容器日志。如果Pod只有一個(gè)容器,容器名稱是可選的 | |
attach | 附加到一個(gè)運(yùn)行的容器 | |
exec | 執(zhí)行命令到容器 | |
port-forward | 轉(zhuǎn)發(fā)一個(gè)或多個(gè)本地端口到一個(gè)pod | |
proxy | 運(yùn)行一個(gè)proxy到Kubernetes API server | |
cp | 拷貝文件或目錄到容器中 | |
auth | 檢查授權(quán) | |
高級命令 | apply | 通過文件名或標(biāo)準(zhǔn)輸入對資源應(yīng)用配置 |
patch | 使用補(bǔ)丁修改、更新資源的字段 | |
replace | 通過文件名或標(biāo)準(zhǔn)輸入替換一個(gè)資源 | |
convert | 不同的API版本之間轉(zhuǎn)換配置文件 | |
設(shè)置命令 | label | 更新資源上的標(biāo)簽 |
annotate | 更新資源上的注釋 | |
completion | 用于實(shí)現(xiàn)kubectl工具自動補(bǔ)全 | |
其他命令 | api-versions | 打印受支持的API版本 |
config | 修改kubeconfig文件(用于訪問API,比如配置認(rèn)證信息) | |
help | 所有命令幫助 | |
plugin | 運(yùn)行一個(gè)命令行插件 |
create與apply命令的異同
- 通過YAML文件建立
kubectl create -f FILENAME [options]
- 通過YAML文件升級deployment
kubectl apply -f FILENAME
- 相同點(diǎn)
如果yaml文件中的kind值為deployment,那么上面這兩個(gè)命令都可以創(chuàng)建一個(gè)deployment,生成相應(yīng)數(shù)量的pod
- 不同點(diǎn)
create命令:是先刪除所有現(xiàn)有的東西,重新根據(jù)yaml文件生成新的。所以要求yaml文件中的配置必須是完整的
apply命令:根據(jù)配置文件里面列出來的內(nèi)容,升級現(xiàn)有的。所以yaml文件的內(nèi)容可以只寫需要升級的屬性
實(shí)例演示:
- 項(xiàng)目的生命周期
創(chuàng)建->發(fā)布->更新->回滾->刪除
1.創(chuàng)建nginx
#常用語法:kubectl run NAME --image=image [--env="key=value"參數(shù)] [--port=port端口] [--replicas=replicas副本集] [--dry-run=bool狀態(tài)] [--overrides=inline-json] [--command命令] -- [COMMAND] [args...] [options]`
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3
#查看pod節(jié)點(diǎn)
kubectl get pods
2.發(fā)布nginx service提供負(fù)載均衡的功能
#常用語法:kubectl expose (-f FILENAME | TYPE NAME) [--port=port群集之間內(nèi)部通信的端口] [--protocol=TCP|UDP|SCTP] [--target-port對外暴露的端口=number-or-name] [--name=name指定名稱] [--external-ip=external-ip-of-service] [--type=type指定類型] [options]
kubectl expose deployment nginx-deployment --port=80 --target-port=80 --name=nginx-deployment-service --type=NodePort
#查看服務(wù)發(fā)布,此處svc位service服務(wù)組件的縮寫
kubectl get pods,svc
#查看后端關(guān)聯(lián)的節(jié)點(diǎn)
kubectl get endpoints
#查看網(wǎng)絡(luò)狀態(tài)詳細(xì)信息
kubectl get pods -o wide
#查看服務(wù)的端口
kubectl get svc
#kubernetes里kube-proxy支持三種模式,在v1.8之前我們使用的是iptables 以及 userspace兩種模式,在kubernetes 1.8之后引入了ipvs模式
#node節(jié)點(diǎn)安裝ipvsadmin工具查看服務(wù)端口
yum install ipvsadm -y
ipvsadm -L -n
#使用工具查看,可見調(diào)度算法為rr輪詢模式
#master端查看訪問日志
kubectl get pods
3.更新nginx 為1.14版本
- 谷歌瀏覽器重新加載刷新頁面查看nginx版本信息
查看nginx版本步驟:F12打開開發(fā)者選項(xiàng)->F5刷新訪問->找到network ->點(diǎn)擊name ->找到headers頭部信息
kubectl set image deployment/nginx-deployment nginx-deployment=nginx:1.14
4.回滾nginx
#查看歷史版本
kubectl rollout history deployment/nginx-deployment
#執(zhí)行回滾到上一次版本
kubectl rollout undo deployment/nginx-deployment
#檢查回滾狀態(tài)
kubectl rollout status deployment/nginx-deployment
5.刪除nginx
#刪除deployment
kubectl delete deployment/nginx-deployment
#刪除服務(wù)SVC
kubectl get svc
6.其他命令
- 查看具體資源的詳細(xì)信息
kubectl describe (-f FILENAME | TYPE [NAME_PREFIX | -l label] | TYPE/NAME) [options]
- 查看deployment資源
kubectl describe deployment/nginx-deployment
- 查看資源對象簡寫
kubectl api-resources
- 進(jìn)入相應(yīng)pod中
kubectl exec POD [-c CONTAINER] -- COMMAND [args...] [options]
- 查看生成的YAML格式文件
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o yaml
- 查看生成的JSON格式文件
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o json
- 生成YAML 、 JSON文件導(dǎo)出
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o json(yaml) > test.json(yaml)
- 將現(xiàn)有資源進(jìn)行導(dǎo)出
kubectl get svc/nginx-svc --export -o yaml > nginx-svc.yaml
- 測試命令正確性,不執(zhí)行(類似shell腳本中的sh -n)
kubectl run nginx --image=nginx --port=80 --replicas=2 --dry-run
謝謝閱讀!
原文鏈接:https://blog.csdn.net/caozhengtao1213/article/details/104269377
相關(guān)推薦
- 2022-02-25 commons-fileupload文件上傳的時(shí)候?qū)懭雸D片無數(shù)據(jù)
- 2022-04-01 k8s使用docker作為運(yùn)行時(shí)卡死解決辦法
- 2022-09-27 Kotlin示例講解標(biāo)準(zhǔn)函數(shù)with與run和apply的使用_Android
- 2023-01-15 Rust包和Crate超詳細(xì)講解_Rust語言
- 2022-09-16 nginx緩存以及清除緩存的使用_nginx
- 2022-04-18 python中的selenium實(shí)現(xiàn)自動向下滾動頁面并指定最大滑動距離_python
- 2023-07-14 瀏覽器本地存儲Cookie、LocalStorage、SessionStorage
- 2021-12-24 Linux系統(tǒng)下netstat命令詳細(xì)介紹_Linux
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支