更新資源
$ 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