欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

kubectl怎么用?

一、kubectl概述

Kubectl是一個命令行界面,用于運(yùn)行針對Kubernetes集群的命令。Kubectl的配置文件在$HOME/.kube目錄。我們可以通過設(shè)置KUBECONFIG環(huán)境變量或設(shè)置命令參數(shù)--kubeconfig來指定其他位置的kubeconfig文件。

二、kubectl語法

1.使用以下語法kubectl從終端窗口運(yùn)行命令:

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)密山免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

kubectl [command] [TYPE] [NAME] [flags]

2.其中command,TYPE,NAME,和flags分別是:

  • command
指定要在一個或多個資源進(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”。
    在對多個資源執(zhí)行操作時,我們可以按類型和名稱指定每個資源,或指定一個或多個文件:

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.要使用一個或多個文件指定資源:

-f file1 -f file2 -f file<#>
#注意使用YAML而不是JSON,因為YAML往往更加用戶友好,特別是對于配置文件。

范例:

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將一個資源公開為一個新的Service
run在集群中運(yùn)行一個特定的鏡像
set在對象上設(shè)置特定的功能
get顯示一個或多個資源
explain文檔參考資料
edit使用默認(rèn)的編輯器編輯一個資源
delete通過文件名、標(biāo)準(zhǔn)輸入、資源名稱或標(biāo)簽選擇器來刪除資源
部署命令rollout管理資源的發(fā)布
rolling-update對給定的復(fù)制控制器滾動更新
scale擴(kuò)容或縮容Pod數(shù)量,Deployment、ReplicaSet、RC或Job
autoscale創(chuàng)建一個自動選擇擴(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在一個Pod中打印一個容器日志。如果Pod只有一個容器,容器名稱是可選的
attach附加到一個運(yùn)行的容器
exec執(zhí)行命令到容器
port-forward轉(zhuǎn)發(fā)一個或多個本地端口到一個pod
proxy運(yùn)行一個proxy到Kubernetes API server
cp拷貝文件或目錄到容器中
auth檢查授權(quán)
高級命令apply通過文件名或標(biāo)準(zhǔn)輸入對資源應(yīng)用配置
patch使用補(bǔ)丁修改、更新資源的字段
replace通過文件名或標(biāo)準(zhǔn)輸入替換一個資源
convert不同的API版本之間轉(zhuǎn)換配置文件
設(shè)置命令label更新資源上的標(biāo)簽
annotate更新資源上的注釋
completion用于實現(xiàn)kubectl工具自動補(bǔ)全
其他命令api-versions打印受支持的API版本
config修改kubeconfig文件(用于訪問API,比如配置認(rèn)證信息)
help所有命令幫助
plugin運(yùn)行一個命令行插件

四、create與apply命令的異同

  • 通過YAML文件建立
kubectl create -f FILENAME [options]
  • 通過YAML文件升級deployment
kubectl apply -f FILENAME
  • 相同點(diǎn)
如果yaml文件中的kind值為deployment,那么上面這兩個命令都可以創(chuàng)建一個deployment,生成相應(yīng)數(shù)量的pod
  • 不同點(diǎn)
create命令:是先刪除所有現(xiàn)有的東西,重新根據(jù)yaml文件生成新的。所以要求yaml文件中的配置必須是完整的
apply命令:根據(jù)配置文件里面列出來的內(nèi)容,升級現(xiàn)有的。所以yaml文件的內(nèi)容可以只寫需要升級的屬性

五、實例演示:

  • 項目的生命周期
    創(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ā)者選項->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

網(wǎng)站題目:kubectl怎么用?
標(biāo)題鏈接:http://chinadenli.net/article28/giocjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、品牌網(wǎng)站設(shè)計、企業(yè)網(wǎng)站制作、做網(wǎng)站、、定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)