建立無狀態工作負載

本文說明如何在 Google Distributed Cloud (GDC) 實體隔離的 Kubernetes 叢集中,建立及管理無狀態工作負載。無狀態工作負載可讓您根據工作負載需求調度應用程式部署作業,完全不必在 Kubernetes 叢集中管理永久儲存空間,即可儲存資料或應用程式狀態。這份文件可協助您開始使用,有效調整及最佳化應用程式的可用性。

本文適用於應用程式運算子群組中的開發人員,負責為所屬機構建立應用程式工作負載。詳情請參閱 GDC air-gapped 說明文件適用對象

事前準備

如要完成本文中的工作,您必須具備下列資源和角色:

  • 如要對 Kubernetes 叢集執行指令,請確認您具備下列資源:

    • 找出 Kubernetes 叢集名稱,或向平台管理員群組成員詢問叢集名稱。

    • 如果沒有 Kubernetes 叢集的 kubeconfig 檔案,請登入並產生該檔案。

    • 請使用 Kubernetes 叢集的 kubeconfig 路徑,替換這些操作說明中的 KUBERNETES_CLUSTER_KUBECONFIG

  • 如要在共用叢集中建立無狀態工作負載,請要求組織 IAM 管理員在專案命名空間中授予您命名空間管理員角色 (namespace-admin)。

  • 如要在標準叢集中建立無狀態工作負載,請要求機構的 IAM 管理員在標準叢集中授予您叢集開發人員角色 (cluster-developer)。

建立 Deployment

如要建立部署作業,請編寫 Deployment 資訊清單,然後執行 kubectl apply 建立資源。這種方法保留對使用中資源所做的更新,而不會將變更併回資訊清單檔案。

如要從資訊清單檔案建立 Deployment,請執行:

kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
    apply -f - <<EOF
apiVersion: apps/v1
kind: Deployment
metadata:
  name: DEPLOYMENT_NAME
spec:
  replicas: NUMBER_OF_REPLICAS
  selector:
    matchLabels:
      run: APP_NAME
  template:
    metadata:
      labels: # The labels given to each pod in the deployment, which are used
              # to manage all pods in the deployment.
        run: APP_NAME
    spec: # The pod specification, which defines how each pod runs in the deployment.
      containers:
      - name: CONTAINER_NAME
        image: CONTAINER_IMAGE
EOF

更改下列內容:

  • KUBERNETES_CLUSTER_KUBECONFIG:要部署容器工作負載的 Kubernetes 叢集 kubeconfig 檔案。

  • NAMESPACE:要部署容器工作負載的命名空間。如果是共用叢集,這必須是專案命名空間。 如果是標準叢集,則可以是任何命名空間。

  • DEPLOYMENT_NAMEDeployment 物件的名稱。

  • APP_NAME:要在部署作業中執行的應用程式名稱。

  • NUMBER_OF_REPLICAS:Deployment 管理的複製 Pod 物件數量。

  • CONTAINER_NAME:容器名稱。

  • CONTAINER_IMAGE:容器映像檔的名稱。您必須加入映像檔的容器登錄路徑和版本,例如 REGISTRY_PATH/hello-app:1.0。如要進一步瞭解如何設定容器登錄路徑,請參閱「Managed Harbor Service 總覽」。

例如:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app
spec:
  replicas: 3
  selector:
    matchLabels:
      run: my-app
  template:
    metadata:
      labels:
        run: my-app
    spec:
      containers:
      - name: hello-app
        image: REGISTRY_PATH/hello-app:1.0

如要將 GPU 工作負載部署至容器,請參閱管理 GPU 容器工作負載一文。

後續步驟