kubectl 命令技巧大全

 

更新資源

$ kubectl rolling-update frontend-v1 -f frontend-v2.json           # 滾動更新 pod frontend-v1
$ kubectl rolling-update frontend-v1 frontend-v2 --image=image:v2  # 更新資源名稱並更新鏡像
$ kubectl rolling-update frontend --image=image:v2                 # 更新 frontend pod 中的鏡像
$ kubectl rolling-update frontend-v1 frontend-v2 --rollback        # 退出已存在的進行中的滾動更新
$ cat pod.json | kubectl replace -f -                              # 基於 stdin 輸入的 JSON 替換 pod

# 強制替換,刪除後重新創建資源。會導致服務中斷。
$ kubectl replace --force -f ./pod.json

# 爲 nginx RC 創建服務,啓用本地 80 端口連接到容器上的 8000 端口
$ kubectl expose rc nginx --port=80 --target-port=8000

# 更新單容器 pod 的鏡像版本(tag)到 v4
$ kubectl get pod mypod -o yaml | sed 's/\(image: myimage\):.*$/\1:v4/' | kubectl replace -f -

$ kubectl label pods my-pod new-label=awesome                      # 添加標籤
$ kubectl annotate pods my-pod icon-url=http://goo.gl/XXBTWq       # 添加註解
$ kubectl autoscale deployment foo --min=2 --max=10                # 自動擴展 deployment “foo”

修補資源

使用策略合併補丁並修補資源。

$ kubectl patch node k8s-node-1 -p '{"spec":{"unschedulable":true}}' # 部分更新節點

# 更新容器鏡像; spec.containers[*].name 是必須的,因爲這是合併的關鍵字
$ kubectl patch pod valid-pod -p '{"spec":{"containers":[{"name":"kubernetes-serve-hostname","image":"new image"}]}}'

# 使用具有位置數組的 json 補丁更新容器鏡像
$ kubectl patch pod valid-pod --type='json' -p='[{"op": "replace", "path": "/spec/containers/0/image", "value":"new image"}]'

# 使用具有位置數組的 json 補丁禁用 deployment 的 livenessProbe
$ kubectl patch deployment valid-deployment  --type json   -p='[{"op": "remove", "path": "/spec/template/spec/containers/0/livenessProbe"}]'

編輯資源

在編輯器中編輯任何 API 資源。

$ kubectl edit svc/docker-registry                      # 編輯名爲 docker-registry 的 service
$ KUBE_EDITOR="nano" kubectl edit svc/docker-registry   # 使用其它編輯器

Scale 資源

$ kubectl scale --replicas=3 rs/foo                                 # Scale a replicaset named 'foo' to 3
$ kubectl scale --replicas=3 -f foo.yaml                            # Scale a resource specified in "foo.yaml" to 3
$ kubectl scale --current-replicas=2 --replicas=3 deployment/mysql  # If the deployment named mysql's current size is 2, scale mysql to 3
$ kubectl scale --replicas=5 rc/foo rc/bar rc/baz                   # Scale multiple replication controllers

刪除資源

$ kubectl delete -f ./pod.json                                              # 刪除 pod.json 文件中定義的類型和名稱的 pod
$ kubectl delete pod,service baz foo                                        # 刪除名爲“baz”的 pod 和名爲“foo”的 service
$ kubectl delete pods,services -l name=myLabel                              # 刪除具有 name=myLabel 標籤的 pod 和 serivce
$ kubectl delete pods,services -l name=myLabel --include-uninitialized      # 刪除具有 name=myLabel 標籤的 pod 和 service,包括尚未初始化的
$ kubectl -n my-ns delete po,svc --all                                      # 刪除 my-ns namespace 下的所有 pod 和 serivce,包括尚未初始化的

與運行中的 Pod 交互

$ kubectl logs my-pod                                 # dump 輸出 pod 的日誌(stdout)
$ kubectl logs my-pod -c my-container                 # dump 輸出 pod 中容器的日誌(stdout,pod 中有多個容器的情況下使用)
$ kubectl logs -f my-pod                              # 流式輸出 pod 的日誌(stdout)
$ kubectl logs -f my-pod -c my-container              # 流式輸出 pod 中容器的日誌(stdout,pod 中有多個容器的情況下使用)
$ kubectl run -i --tty busybox --image=busybox -- sh  # 交互式 shell 的方式運行 pod
$ kubectl attach my-pod -i                            # 連接到運行中的容器
$ kubectl port-forward my-pod 5000:6000               # 轉發 pod 中的 6000 端口到本地的 5000 端口
$ kubectl exec my-pod -- ls /                         # 在已存在的容器中執行命令(只有一個容器的情況下)
$ kubectl exec my-pod -c my-container -- ls /         # 在已存在的容器中執行命令(pod 中有多個容器的情況下)
$ kubectl top pod POD_NAME --containers               # 顯示指定 pod 和容器的指標度量

與節點和集羣交互

$ kubectl cordon my-node                                                # 標記 my-node 不可調度
$ kubectl drain my-node                                                 # 清空 my-node 以待維護
$ kubectl uncordon my-node                                              # 標記 my-node 可調度
$ kubectl top node my-node                                              # 顯示 my-node 的指標度量
$ kubectl cluster-info                                                  # 顯示 master 和服務的地址
$ kubectl cluster-info dump                                             # 將當前集羣狀態輸出到 stdout                                    
$ kubectl cluster-info dump --output-directory=/path/to/cluster-state   # 將當前集羣狀態輸出到 /path/to/cluster-state

# 如果該鍵和影響的污點(taint)已存在,則使用指定的值替換
$ kubectl taint nodes foo dedicated=special-user:NoSchedule

 

 

發佈了17 篇原創文章 · 獲贊 1 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章