노드 풀 관리하기

Google Distributed Cloud (GDC) 에어 갭 Kubernetes 클러스터를 만들 때는 지정한 노드 수 및 노드 유형을 사용해서 클러스터의 첫 번째 노드 풀을 만듭니다. 기존 클러스터의 컴퓨팅 요구사항이 변경되면 다음 노드 풀 작업을 실행할 수 있습니다.

  • 새 노드 풀 추가: 클러스터 워크로드 수요가 증가하면 새 노드 풀을 추가합니다.

  • 노드 풀 보기: 기존 노드 풀의 특성과 상태를 봅니다.

  • 노드 풀 크기 조절: 워크로드 트래픽 변동에 맞게 노드 풀을 수동으로 확장 또는 축소합니다.

  • 노드 풀 삭제: 클러스터 워크로드 수요가 감소하거나 컨테이너 작업에 더 이상 적합하지 않은 머신 유형을 삭제하려는 경우 노드 풀을 삭제합니다.

클러스터의 노드 풀에 대한 자세한 내용은 노드 정보를 참조하세요.

이 문서는 애플리케이션 운영자 그룹의 애플리케이션 개발자와 조직 내에서 Kubernetes 클러스터를 관리하는 플랫폼 관리자 그룹의 IT 관리자를 대상으로 합니다. 자세한 내용은 다음 자료를 참조하세요. GDC 에어 갭 문서의 대상 독자

시작하기 전에

이 문서의 작업을 완료하려면 다음 리소스와 역할이 있어야 합니다.

노드 풀 추가

기존 Kubernetes 클러스터에 노드 풀을 추가하려면 다음 단계를 완료하세요.

콘솔

  1. 탐색 메뉴에서 Kubernetes Engine > 클러스터 를 선택합니다.
  2. 클러스터 목록에서 클러스터를 클릭합니다. 클러스터 세부정보 페이지가 표시됩니다.
  3. 노드 풀 > 노드 풀 추가 를 선택합니다.
  4. 노드 풀의 이름을 할당합니다. 노드 풀을 만든 후에는 이름을 수정할 수 없습니다.
  5. 노드 풀에서 만들 워커 노드 수를 지정합니다.
  6. 워크로드 요구사항에 가장 적합한 머신 클래스를 선택합니다. 머신 클래스는 다음 설정에 표시됩니다.
    • 머신 유형
    • vCPU
    • 메모리
  7. 저장 을 클릭합니다.

API

  1. 대화형 편집기를 사용하여 kubectl CLI로 Cluster 커스텀 리소스 사양을 엽니다.

    kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \
        -n KUBERNETES_CLUSTER_NAMESPACE \
        --kubeconfig MANAGEMENT_API_SERVER
    

    다음을 바꿉니다.

    • KUBERNETES_CLUSTER_NAME: 클러스터의 이름입니다.
    • KUBERNETES_CLUSTER_NAMESPACE: 클러스터의 네임스페이스입니다. 공유 클러스터의 경우 platform 네임스페이스를 사용합니다. Standard 클러스터의 경우 클러스터의 프로젝트 네임스페이스를 사용합니다.
    • MANAGEMENT_API_SERVER: Kubernetes 클러스터가 호스팅되는 영역 API 서버의 kubeconfig 경로입니다. 아직 대상 영역에서 API 서버의 kubeconfig 파일을 생성하지 않은 경우 로그인에서 세부정보를 확인하세요.
  2. nodePools 섹션에 새 항목을 추가합니다.

    nodePools:
    # Several lines of code are omitted here.
    - machineTypeName: MACHINE_TYPE
      name: NODE_POOL_NAME
      nodeCount: NUMBER_OF_WORKER_NODES
      taints: TAINTS
      labels: LABELS
      acceleratorOptions:
        gpuPartitionScheme: GPU_PARTITION_SCHEME
    

    다음을 바꿉니다.

    • MACHINE_TYPE: 노드 풀의 워커 노드에 사용할 머신 유형입니다. 구성할 수 있는 사용 가능한 머신 유형을 봅니다.
    • NODE_POOL_NAME: 노드 풀의 이름입니다.
    • NUMBER_OF_WORKER_NODES: 노드 풀에서 프로비저닝할 워커 노드 수입니다.
    • TAINTS: 이 노드 풀의 노드에 적용할 taint입니다. 이 필드는 선택 사항입니다.
    • LABELS: 이 노드 풀의 노드에 적용할 라벨입니다. 키-값 쌍 목록을 포함합니다. 이 필드는 선택 사항입니다.
    • GPU_PARTITION_SCHEME: GPU 워크로드를 실행하는 경우 GPU 파티셔닝 스키마입니다. 예를 들면 mixed-2입니다. 이 필드가 설정되지 않은 경우 GPU가 파티셔닝되지 않습니다. 사용 가능한 멀티 인스턴스 GPU (MIG) 프로필은 지원되는 MIG 프로필을 참조하세요.
  3. 파일을 저장하고 편집기를 종료합니다.

노드 풀 보기

Kubernetes 클러스터에서 기존 노드 풀을 보려면 다음 단계를 완료하세요.

콘솔

  1. 탐색 메뉴에서 Kubernetes Engine > 클러스터 를 선택합니다.
  2. 클러스터 목록에서 클러스터를 클릭합니다. 클러스터 세부정보 페이지가 표시됩니다.
  3. 노드 풀 을 선택합니다.

클러스터에서 실행 중인 노드 풀 목록이 표시됩니다. 이 페이지에서 클러스터의 노드 풀을 관리할 수 있습니다.

API

  • 특정 Kubernetes 클러스터의 노드 풀을 봅니다.

    kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \
        -n KUBERNETES_CLUSTER_NAMESPACE \
        -o json --kubeconfig MANAGEMENT_API_SERVER | \
        jq .status.workerNodePoolStatuses
    

    다음을 바꿉니다.

    • KUBERNETES_CLUSTER_NAME: 클러스터의 이름입니다.
    • KUBERNETES_CLUSTER_NAMESPACE: 클러스터의 네임스페이스입니다. 공유 클러스터의 경우 platform 네임스페이스를 사용합니다. Standard 클러스터의 경우 클러스터의 프로젝트 네임스페이스를 사용합니다.

    출력은 다음과 비슷합니다.

    [
      {
        "conditions": [
          {
            "lastTransitionTime": "2023-08-31T22:16:17Z",
            "message": "",
            "observedGeneration": 2,
            "reason": "NodepoolReady",
            "status": "True",
            "type": "Ready"
          },
          {
            "lastTransitionTime": "2023-08-31T22:16:17Z",
            "message": "",
            "observedGeneration": 2,
            "reason": "ReconciliationCompleted",
            "status": "False",
            "type": "Reconciling"
          }
        ],
        "name": "worker-node-pool",
        "readyNodes": 3,
        "readyTimestamp": "2023-08-31T18:59:46Z",
        "reconcilingNodes": 0,
        "stalledNodes": 0,
        "unknownNodes": 0
      }
    ]
    

노드 풀 크기 조절

풀을 확장 또는 축소하여 Kubernetes 클러스터에서 노드 풀의 크기를 수동으로 조절할 수 있습니다. 노드 풀을 축소할 때 삭제할 특정 노드를 선택할 수 없습니다.

기존 클러스터에서 노드 풀의 크기를 조절하려면 다음 단계를 완료하세요.

콘솔

  1. 대시보드에서 수정하려는 클러스터가 있는 프로젝트를 선택합니다.
  2. 탐색 메뉴에서 Kubernetes Engine > 클러스터 를 선택합니다.
  3. 노드 풀이 연결된 클러스터 이름을 선택합니다. 클러스터 세부정보 페이지가 표시됩니다.
  4. 노드 풀 탭을 클릭합니다.
  5. 크기를 조절할 노드 풀의 수정 아이콘을 선택합니다. 노드 풀 수정 메시지가 표시됩니다.
  6. 노드 풀에 필요한 새 노드 수를 반영하도록 노드 수 필드를 업데이트합니다. 워크로드 요구사항에 맞게 노드 수를 늘리거나 줄일 수 있습니다.

  7. 저장 을 클릭합니다.

  8. 클러스터의 노드 풀 탭으로 돌아가서 크기가 조절된 노드 풀의 상태가 Ready이고 노드 수가 올바른지 확인합니다. 노드 풀이 사양에 맞게 확장되는 데 몇 분 정도 걸릴 수 있습니다.

    콘솔을 사용하여 노드 풀이 준비되었는지 확인합니다.

API

  1. 대화형 편집기를 사용하여 kubectl CLI로 Cluster 커스텀 리소스 사양을 엽니다.

    kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \
        -n KUBERNETES_CLUSTER_NAMESPACE \
        --kubeconfig MANAGEMENT_API_SERVER
    

    다음을 바꿉니다.

    • KUBERNETES_CLUSTER_NAME: 노드 풀을 호스팅하는 클러스터의 이름입니다.
    • KUBERNETES_CLUSTER_NAMESPACE: 클러스터의 네임스페이스입니다. 공유 클러스터의 경우 platform 네임스페이스를 사용합니다. Standard 클러스터의 경우 클러스터의 프로젝트 네임스페이스를 사용합니다.
    • MANAGEMENT_API_SERVER: Kubernetes 클러스터가 호스팅되는 영역 API 서버의 kubeconfig 경로입니다. 아직 대상 영역에서 API 서버의 kubeconfig 파일을 생성하지 않은 경우 영역 관리 API 서버 리소스를 참조하세요.
  2. 크기를 조절할 노드 풀의 nodeCount 필드를 업데이트합니다.

    nodePools:
    # Several lines of code are omitted here.
    - machineTypeName: n2-standard-2-gdc
      name: nodepool-1
      nodeCount: NUMBER_OF_WORKER_NODES
    

    NUMBER_OF_WORKER_NODES를 노드 풀에서 프로비저닝할 업데이트된 워커 노드 수로 바꿉니다.

  3. 파일을 저장하고 편집기를 종료합니다.

  4. 노드 풀의 구성을 확인하여 노드 확장이 완료되었는지 확인합니다.

    kubectl get clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \
        -n KUBERNETES_CLUSTER_NAMESPACE -o json \
        --kubeconfig MANAGEMENT_API_SERVER | jq .status.workerNodePoolStatuses
    

    readyNodes 수가 노드 풀에 설정한 노드 수를 반영하는지 확인합니다. 노드 풀이 사양에 맞게 확장되는 데 몇 분 정도 걸릴 수 있습니다.

노드 풀 삭제

노드 풀을 삭제하면 노드와 노드 경로가 삭제됩니다. 이러한 노드는 실행 중인 포드를 제거하고 다시 예약합니다. 포드에 특정 노드 선택기가 있는 경우, 클러스터의 다른 노드가 기준을 충족하지 못하면 포드는 예약되지 않은 상태로 남아 있을 수 있습니다.

노드 풀을 삭제하기 전에 워커 노드가 3개 이상 있는지 확인하여 클러스터에 효과적으로 실행할 수 있는 컴퓨팅 공간이 충분하도록 합니다.

노드 풀을 삭제하려면 다음 단계를 완료하세요.

콘솔

  1. 탐색 메뉴에서 Kubernetes Engine > 클러스터 를 선택합니다.

  2. 삭제할 노드 풀을 호스팅하는 클러스터를 클릭합니다.

  3. 노드 풀 을 선택합니다.

  4. 삭제할 노드 풀 옆에 있는 삭제를 클릭합니다.

API

  1. 대화형 편집기를 사용하여 kubectl CLI로 Cluster 커스텀 리소스 사양을 엽니다.

    kubectl edit clusters.cluster.gdc.goog/KUBERNETES_CLUSTER_NAME \
        -n KUBERNETES_CLUSTER_NAMESPACE \
        --kubeconfig MANAGEMENT_API_SERVER
    

    다음을 바꿉니다.

    • KUBERNETES_CLUSTER_NAME: 클러스터의 이름입니다.
    • KUBERNETES_CLUSTER_NAMESPACE: 클러스터의 네임스페이스입니다. 공유 클러스터의 경우 platform 네임스페이스를 사용합니다. Standard 클러스터의 경우 클러스터의 프로젝트 네임스페이스를 사용합니다.
    • MANAGEMENT_API_SERVER: Kubernetes 클러스터가 호스팅되는 영역 API 서버의 kubeconfig 경로입니다. 아직 대상 영역에서 API 서버의 kubeconfig 파일을 생성하지 않은 경우 영역 관리 API 서버 리소스를 참조하세요.
  2. nodePools 섹션에서 노드 풀 항목을 삭제합니다. 예를 들어 다음 스니펫에서는 machineTypeName, name, nodeCount 필드를 삭제해야 합니다.

    nodePools:
    # Several lines of code are omitted here.
    - machineTypeName: n2-standard-2-gdc
      name: nodepool-1
      nodeCount: 3
    

    삭제하는 노드 풀의 모든 필드를 삭제해야 합니다.

  3. 파일을 저장하고 편집기를 종료합니다.

다음 단계