このページでは、Google Distributed Cloud(GDC)のエアギャップ Kubernetes クラスタで実行されている既存のステートレス ワークロードを検査する方法について説明します。ステートレス ワークロードを使用すると、データやアプリケーションの状態を保存せずにアプリケーションのデプロイを実行できます。GDC コンソールまたは kubectl CLI を使用してステートレス ワークロードを表示し、リソース使用量とワークロードの健全性をモニタリングできます。
このページは、組織のアプリケーション ワークロードの管理を担当するアプリケーション オペレーター グループ内のデベロッパーを対象としています。詳細については、GDC エアギャップの対象読者に関するドキュメントをご覧ください。
始める前に
Kubernetes クラスタに対してコマンドを実行するには、次のリソースがあることを確認してください。
Kubernetes クラスタ名を確認するか、プラットフォーム管理者にクラスタ名を確認します。
まだ Kubernetes クラスタの kubeconfig ファイルがない場合は、ログインして生成します。
これらの手順では、Kubernetes クラスタの kubeconfig パスを使用して
KUBERNETES_CLUSTER_KUBECONFIGを置き換えます。
プロジェクトにデプロイされたすべてのワークロードを表示するために必要な権限を取得するには、組織の IAM 管理者に、プロジェクトの Namespace でワークロード閲覧者ロール(workload-viewer)を付与するよう依頼してください。
ステートレス ワークロードを検査するために必要な権限を取得するには、組織の IAM 管理者に、プロジェクトの Namespace で Namespace 管理者ロール(namespace-admin)を付与するよう依頼してください。
プロジェクトのコンテナ ワークロードを表示する
プロジェクトのコンテナ ワークロードを表示するには、次の操作を行います。
コンソール
ナビゲーション メニューで、[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: プロジェクトの Namespace。DEPLOYMENT_NAME:Deploymentオブジェクトの名前。
ライブ構成を YAML 形式で表示する
Deployment オブジェクトのマニフェストを表示するには、次のコマンドを実行します。
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
get deployments DEPLOYMENT_NAME -o yaml
このコマンドは、Deployment オブジェクトのライブ構成を YAML 形式で表示します。
ポッドの一覧表示
Deployment によって作成された Pod オブジェクトを一覧表示するには、次のコマンドを実行します。
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
get pods -l KEY=VALUE
このコマンドで -l フラグを指定すると、指定されたクラスタ内の指定された Key-Value ペアのラベルを持つすべての Pod オブジェクトが一覧表示されます。
次のように置き換えます。
KUBERNETES_CLUSTER_KUBECONFIG: デプロイを実行しているクラスタの kubeconfig ファイル。NAMESPACE: プロジェクトの Namespace。KEY: デプロイで設定された Key-Value ペアのラベルのキー。たとえば、.template.metadata.labelsフィールドにapp: myappラベルが構成されている場合、キーはappです。VALUE: デプロイで設定された Key-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: プロジェクトの Namespace。POD_NAME: デプロイによって管理される Pod の名前。