本文說明如何檢查在 Google Distributed Cloud (GDC) 實體隔離 Kubernetes 叢集中執行的現有無狀態工作負載。無狀態工作負載可讓您執行應用程式部署作業,不必儲存資料或應用程式狀態。您可以使用 GDC 控制台或 kubectl CLI 查看無狀態工作負載,監控資源用量和工作負載健康狀態。
本文適用於應用程式運算子群組中的開發人員,負責管理機構的應用程式工作負載。詳情請參閱 GDC air-gapped 說明文件適用對象。
事前準備
如要完成本文中的工作,您必須具備下列資源和角色:
如要對 Kubernetes 叢集執行指令,請確認您具備下列資源:
找出 Kubernetes 叢集名稱,或向平台管理員群組成員詢問叢集名稱。
如果沒有 Kubernetes 叢集的 kubeconfig 檔案,請登入並產生該檔案。
請使用 Kubernetes 叢集的 kubeconfig 路徑,替換這些操作說明中的
KUBERNETES_CLUSTER_KUBECONFIG。
如要取得必要權限,查看部署至共用叢集的所有工作負載,請要求機構 IAM 管理員在專案命名空間中,授予您「工作負載檢視者」角色 (
workload-viewer)。如要取得檢查共用叢集中無狀態工作負載所需的權限,請要求組織 IAM 管理員在專案命名空間中授予您命名空間管理員角色 (
namespace-admin)。如要取得在標準叢集中查看及檢查無狀態工作負載的必要權限,請要求組織 IAM 管理員在標準叢集中授予您叢集開發人員角色 (
cluster-developer)。
查看專案的容器工作負載
如要查看專案的容器工作負載,請完成下列步驟:
控制台
在導覽選單中,依序選取「Kubernetes Engine」>「工作負載」。
您可以查看容器工作負載的詳細資料,例如:
- 名稱
- 類型
- Pod 數量
- Kubernetes 叢集
- 上次修改日期
容器工作負載會依所屬的 Kubernetes 叢集分類。選取「叢集」下拉式選單,切換叢集內容。
CLI
執行下列指令,列出專案中的所有 Pod:
kubectl get pods -n PROJECT_NAMESPACE輸出結果會與下列內容相似:
NAME READY STATUS RESTARTS AGE nginx-workload-ah-aa-1228 1/1 Running 0 12h nginx-workload-ah-ab-6784 1/1 Running 0 11h nginx-workload-ah-ac-0045 1/1 Running 0 12h
檢查部署作業
如要要求取得 Deployment 資源元件的詳細資訊,請執行直接以要檢查的實體為目標的指令。
取得 Deployment 物件資訊
如要取得 Deployment 物件的詳細資訊,請執行下列指令:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
describe deployment DEPLOYMENT_NAME
更改下列內容:
KUBERNETES_CLUSTER_KUBECONFIG:執行部署作業的叢集 kubeconfig 檔案。NAMESPACE:命名空間。如果是共用叢集,這必須是專案命名空間。如果是標準叢集,則可以是任何命名空間。DEPLOYMENT_NAME:Deployment物件的名稱。
以 YAML 格式顯示即時設定
如要查看 Deployment 物件的資訊清單,請執行:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
get deployments DEPLOYMENT_NAME -o yaml
這個指令會以 YAML 格式顯示 Deployment 物件的使用中設定。
列出 Pod
如要列出部署作業建立的 Pod 物件,請執行:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
get pods -l KEY=VALUE
在這個指令中,-l 標記會列出指定叢集中,具有指定鍵/值組合標籤的所有 Pod 物件。
更改下列內容:
KUBERNETES_CLUSTER_KUBECONFIG:執行部署作業的叢集 kubeconfig 檔案。NAMESPACE:命名空間。如果是共用叢集,這必須是專案命名空間。如果是標準叢集,則可以是任何命名空間。KEY:在部署作業中設定的鍵/值組合標籤集的鍵。舉例來說,如果.template.metadata.labels欄位已設定app: myapp標籤,則鍵為app。VALUE:在部署作業中設定的鍵/值組合標籤值。舉例來說,如果.template.metadata.labels欄位已設定app: myapp標籤,則值為my-app。
舉例來說,如果您為 Deployment 物件加上 app: my-app 標籤,可以執行下列指令,查看有該標籤的 Pod 物件:
kubectl --kubeconfig /tmp/kubeconfig.yaml -n my-namespace \
get pods -l app=my-app
取得特定 Pod 的資訊
如要取得特定 Pod 物件的資訊,請執行:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
describe pod POD_NAME
更改下列內容:
KUBERNETES_CLUSTER_KUBECONFIG:執行部署作業的叢集 kubeconfig 檔案。NAMESPACE:命名空間。如果是共用叢集,這必須是專案命名空間。如果是標準叢集,則可以是任何命名空間。POD_NAME:部署作業管理的 Pod 名稱。