調度無狀態工作負載資源

本文說明如何調度在 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 資源,請完成下列步驟:

  1. 為確保水平 Pod 自動調度器能適當測量 CPU 百分比,請在部署作業中設定 CPU 資源要求

  2. 在部署作業中設定水平 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 數量上限。

  3. 檢查水平 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 物件數量。

後續步驟