本文說明如何調度在 Google Distributed Cloud (GDC) 氣隙 Kubernetes 叢集中執行的現有無狀態工作負載。隨著容器工作負載需求演變,您必須調整無狀態工作負載中執行的 Pod。
本文適用於應用程式運算子群組中的開發人員,負責管理機構的應用程式工作負載。詳情請參閱 GDC air-gapped 說明文件適用對象。
事前準備
如要完成本文中的工作,您必須具備下列資源和角色:
如要對 Kubernetes 叢集執行指令,請確認您具備下列資源:
找出 Kubernetes 叢集名稱,或向平台管理員群組成員詢問叢集名稱。
如果沒有 Kubernetes 叢集的 kubeconfig 檔案,請登入並產生該檔案。
請使用 Kubernetes 叢集的 kubeconfig 路徑,替換這些操作說明中的
KUBERNETES_CLUSTER_KUBECONFIG。
如要取得在共用叢集中擴充無狀態工作負載所需的權限,請要求組織 IAM 管理員在專案命名空間中授予您命名空間管理員角色 (
namespace-admin)。如要取得在標準叢集中擴充無狀態工作負載所需的權限,請要求組織 IAM 管理員在標準叢集中授予叢集開發人員角色 (
cluster-developer)。
調度 Deployment 資源
使用 Kubernetes 的擴縮功能,適當擴縮部署中執行的 Pod 數量。
自動調度部署的 Pod 資源
Kubernetes 提供自動調度資源功能,因此需求變化時,您不必手動更新部署作業。如要自動調度部署的 Pod 資源,請完成下列步驟:
為確保水平 Pod 自動調度器能適當測量 CPU 百分比,請在部署作業中設定 CPU 資源要求。
在部署作業中設定水平 Pod 自動配置器:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \ -n NAMESPACE \ autoscale deployment DEPLOYMENT_NAME \ --cpu-percent=CPU_PERCENT \ --min=MIN_NUMBER_REPLICAS \ --max=MAX_NUMBER_REPLICAS更改下列內容:
KUBERNETES_CLUSTER_KUBECONFIG:叢集的 kubeconfig 檔案。NAMESPACE:命名空間。如果是共用叢集,這必須是專案命名空間。如果是標準叢集,則可以是任何命名空間。DEPLOYMENT_NAME:要自動調整規模的部署作業名稱。CPU_PERCENT:所有 Pod 的目標平均 CPU 使用率 (以百分比表示)。MIN_NUMBER_REPLICAS:自動配置器可佈建的 Pod 數量下限。MAX_NUMBER_REPLICAS:自動配置器可佈建的 Pod 數量上限。
檢查水平 Pod 自動調度器的目前狀態:
kubectl get hpa輸出結果會與下列內容相似:
NAME REFERENCE TARGET MINPODS MAXPODS REPLICAS AGE DEPLOYMENT_NAME Deployment/DEPLOYMENT_NAME/scale 0% / 50% 1 10 1 18s
手動調度 Deployment 的 Pod
如要手動調度 Deployment 的資源,請執行下列指令:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \
-n NAMESPACE \
scale deployment DEPLOYMENT_NAME \
--replicas NUMBER_OF_REPLICAS
更改下列內容:
KUBERNETES_CLUSTER_KUBECONFIG:叢集的 kubeconfig 檔案。NAMESPACE:命名空間。如果是共用叢集,這必須是專案命名空間。如果是標準叢集,則可以是任何命名空間。DEPLOYMENT_NAME:要自動調整規模的部署作業名稱。DEPLOYMENT_NAME:部署作業中複製的Pod物件數量。