스테이트리스(Stateless) 워크로드 검사

이 페이지에서는 Google Distributed Cloud (GDC) 에어 갭 어플라이언스 Kubernetes 클러스터에서 실행되는 기존 스테이트리스 워크로드를 검사하는 방법을 설명합니다. 스테이트리스(Stateless) 워크로드를 사용하면 데이터나 애플리케이션 상태를 저장하지 않고도 애플리케이션 배포를 실행할 수 있습니다. GDC 콘솔 또는 kubectl CLI를 사용하여 스테이트리스 워크로드를 확인하여 리소스 사용량과 워크로드 상태를 모니터링할 수 있습니다.

이 페이지는 조직의 애플리케이션 워크로드를 관리하는 애플리케이션 운영자 그룹의 개발자를 위한 페이지입니다.

시작하기 전에

사전 구성된 베어메탈 Kubernetes 클러스터에 대해 명령어를 실행하려면 다음 리소스가 있어야 합니다.

  1. Kubernetes 클러스터 이름을 찾거나 플랫폼 관리자에게 클러스터 이름을 문의합니다.

  2. Kubernetes 클러스터의 kubeconfig 파일이 없는 경우 로그인 및 생성합니다.

  3. Kubernetes 클러스터의 kubeconfig 경로를 사용하여 이 안내의 CLUSTER_KUBECONFIG를 바꿉니다.

프로젝트에 배포된 모든 워크로드를 보는 데 필요한 권한을 얻으려면 조직 IAM 관리자에게 프로젝트 네임스페이스에 워크로드 뷰어 역할(workload-viewer)을 부여해 달라고 요청하세요.

상태 비저장 워크로드를 검사하는 데 필요한 권한을 얻으려면 조직 IAM 관리자에게 프로젝트 네임스페이스에 네임스페이스 관리자 역할 (namespace-admin)을 부여해 달라고 요청하세요.

프로젝트의 컨테이너 워크로드 보기

다음 명령어를 실행하여 프로젝트의 모든 포드를 나열합니다.

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_NAME: Deployment 객체 이름

라이브 구성을 YAML 형식으로 표시

Deployment 객체의 매니페스트를 보려면 다음을 실행합니다.

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

이 명령어는 Deployment 객체의 라이브 구성을 YAML 형식으로 표시합니다.

포드 나열

배포에서 생성된 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 객체에 대한 정보를 가져오려면 다음을 실행합니다.

kubectl --kubeconfig CLUSTER_KUBECONFIG -n NAMESPACE \
    describe pod POD_NAME

다음을 바꿉니다.

  • CLUSTER_KUBECONFIG: 배포를 실행하는 Kubernetes 클러스터의 kubeconfig 파일입니다.

  • NAMESPACE: 프로젝트 네임스페이스입니다.

  • POD_NAME: 배포에서 관리하는 포드의 이름입니다.