kubectl常用命令詳解


語法格式

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

 command:子命令、用於操作kubernetes集群資源對象的命令,例如create、delete、describe、get、apply等
 
 TYPE:資源對象類型,區分大小寫,能以單數形式,復數形式或簡寫形式表示。以下三種是等價的
   kubectl get pod pod1
         kubectl get pods pod1
         kubectl get po pod1
         
 NAME:資源對象的名稱,區分大小寫。如果不指定名稱,則系統返回屬於TYPE的全部對象的列表,例如kubectl get pods將返回所有Pod的列表
 
 flags:kubectl子命令的可選參數。
  -s或 --server :指定APIserver的地址和端口
  --kubeconfig :使用kubeconfig配置文件路徑。默認為~/.kube/config
  
  -n或 --namespace:命令執行的目標名稱空間。

一、查看類

# 獲取節點和服務版本信息
kubectl get nodes 

# 獲取節點和服務版本信息,並查看附加信息 
kubectl get nodes -o wide 

# 獲取pod信息,默認是default名稱空間 
kubectl get pod

# 獲取pod信息,默認是default名稱空間,並查看附加信息【如:pod的IP及在哪個節點運行】 
kubectl get pod -o wide

# 獲取指定名稱空間的pod 
kubectl get pod -n kube-system

# 獲取指定名稱空間中的指定pod 
kubectl get pod -n kube-system podName

# 獲取所有名稱空間的pod 
kubectl get pod -A

# 查看pod的詳細信息,以yaml格式或json格式顯示
kubectl get pods -o yaml
kubectl get pods -o json 

# 查看pod的標簽信息
kubectl get pod -A --show-labels 

# 根據Selector(label query)來查詢pod 
kubectl get pod -A --selector="k8s-app=kube-dns" 

# 查看運行pod的環境變量
kubectl exec podName env 

# 查看指定pod的日志 
kubectl logs -f --tail 500 -n kube-system kube-apiserver-k8s-master 

# 查看所有名稱空間的service信息
kubectl get svc -A 

# 查看指定名稱空間的service信息 
kubectl get svc -n kube-system 

# 查看componentstatuses信息
kubectl get cs 

# 查看所有configmaps信息
kubectl get cm -A

# 查看所有serviceaccounts信息
kubectl get sa -A 

# 查看所有daemonsets信息 
kubectl get ds -A 

# 查看所有deployments信息 
kubectl get deploy -A 

# 查看所有replicasets信息
kubectl get rs -A 

# 查看所有statefulsets信息
kubectl get sts -A 

# 查看所有jobs信息 
kubectl get jobs -A 

# 查看所有ingresses信息
kubectl get ing -A 

# 查看有哪些名稱空間 
kubectl get ns 

# 查看pod的描述信息
kubectl describe pod podName 
kubectl describe pod -n kube-system kube-apiserver-k8s-master 

# 查看指定名稱空間中指定deploy的描述信息
kubectl describe deploy -n kube-system coredns 

# 查看node或pod的資源使用情況 # 需要heapster 或metrics-server支持 
kubectl top node
kubectl top pod 

# 查看集群信息
kubectl cluster-info
kubectl cluster-info dump 

# 查看各組件信息【172.16.1.110為master機器】
kubectl -s https://172.16.1.110:6443 get componentstatuses

二、操作類

# 創建資源 
kubectl create -f xxx.yaml

# 應用資源 
kubectl apply -f xxx.yaml

# 應用資源,該目錄下的所有 .yaml, .yml, 或 .json 文件都會被使用
kubectl apply -f 

# 創建test名稱空間 
kubectl create namespace test 

# 刪除資源
kubectl delete -f xxx.yaml
kubectl delete -f 

# 刪除指定的pod
kubectl delete pod podName 

# 刪除指定名稱空間的指定pod 
kubectl delete pod -n test podName 

# 刪除其他資源 
kubectl delete svc svcName 
kubectl delete deploy deployName 
kubectl delete ns nsName 

# 強制刪除 
kubectl delete pod podName -n nsName --grace-period=0 --force 
kubectl delete pod podName -n nsName --grace-period=1
kubectl delete pod podName -n nsName --now 

# 編輯資源
kubectl edit pod podName

三、進階操作

# kubectl exec:進入pod啟動的容器 
kubectl exec -it podName -n nsName /bin/sh #進入容器 

# kubectl label:添加label值 
kubectl label nodes k8s-node01 zone=north #為指定節點添加標簽 
kubectl label nodes k8s-node01 zone- #為指定節點刪除標簽 
kubectl label pod podName -n nsName role-name=test #為指定pod添加標簽
kubectl label pod podName -n nsName role-name=dev --overwrite #修改lable標簽值
kubectl label pod podName -n nsName role-name- #刪除lable標簽

# kubectl滾動升級;
kubectl apply -f myapp-deployment-v2.yaml #通過配置文件滾動升級
kubectl set image deploy/myapp-deployment myapp="registry.cn-beijing.aliyuncs.com/google_registry/myapp:v3" #通過命令滾動升級 
kubectl rollout undo deploy/myapp-deployment 或者 kubectl rollout undo deploy myapp-deployment #pod回滾到前一個版本
kubectl rollout undo deploy/myapp-deployment --to-revision=2 #回滾到指定歷史版本 

# kubectl scale:動態伸縮
kubectl scale deploy myapp-deployment --replicas=5 # 動態伸縮
kubectl scale --replicas=8 -f myapp-deployment-v2.yaml #動態伸縮【根據資源類型和名稱伸縮,其他配置


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM