检查无状态工作负载

本页面介绍了如何检查在 Google Distributed Cloud (GDC) 气隙设备 Kubernetes 集群中运行的现有无状态工作负载。借助无状态工作负载,您可以运行应用部署,而无需存储数据或应用状态。您可以使用 GDC 控制台或 kubectl CLI 查看无状态工作负载,以监控资源使用情况和工作负载运行状况。

本页面适用于应用运维人员群组中的开发者,他们负责管理组织的应用工作负载。

准备工作

如需针对预配置的裸金属 Kubernetes 集群运行命令,请确保您拥有以下资源:

  1. 找到 Kubernetes 集群名称,或向平台管理员询问集群名称。

  2. 登录并生成 Kubernetes 集群的 kubeconfig 文件(如果您还没有)。

  3. 使用 Kubernetes 集群的 kubeconfig 路径替换这些说明中的 CLUSTER_KUBECONFIG

如需获得查看项目中部署的所有工作负载所需的权限,请让您的组织 IAM 管理员为您授予项目命名空间中的“工作负载查看者”角色 (workload-viewer)。

如需获得检查无状态工作负载所需的权限,请让您的组织 IAM 管理员为您授予项目命名空间中的命名空间管理员角色 (namespace-admin)。

查看项目的容器工作负载

运行以下命令可列出项目中的所有 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 CLUSTER_KUBECONFIG -n NAMESPACE \
    describe deployment DEPLOYMENT_NAME

替换以下内容:

  • CLUSTER_KUBECONFIG:运行部署的 Kubernetes 集群的 kubeconfig 文件。

  • NAMESPACE:项目命名空间。

  • DEPLOYMENT_NAMEDeployment 对象的名称。

以 YAML 格式显示实时配置

如需查看 Deployment 对象的清单,请运行以下命令:

kubectl --kubeconfig CLUSTER_KUBECONFIG -n NAMESPACE \
    get deployments DEPLOYMENT_NAME -o yaml

此命令以 YAML 格式显示 Deployment 对象的有效配置。

列出 pod

如需列出由部署创建的 Pod 对象,请运行以下命令:

kubectl --kubeconfig CLUSTER_KUBECONFIG -n NAMESPACE \
    get pods -l KEY=VALUE

在此命令中,-l 标志会列出具有指定键值对标签的所有 Pod 对象。

替换以下内容:

  • CLUSTER_KUBECONFIG:运行部署的 Kubernetes 集群的 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 CLUSTER_KUBECONFIG -n NAMESPACE \
    describe pod POD_NAME

替换以下内容:

  • CLUSTER_KUBECONFIG:运行部署的 Kubernetes 集群的 kubeconfig 文件。

  • NAMESPACE:项目命名空间。

  • POD_NAME:由部署管理的 pod 的名称。