GKE Autopilot 클러스터로 애플리케이션 마이그레이션 및 배포

마이그레이션된 컨테이너 워크로드를 GKE Autopilot 클러스터에 배포하려면 기존 아키텍처에 사용한 절차와 동일한 절차를 사용하여 워크로드를 마이그레이션합니다. 유일한 변경사항은 다음과 같습니다.

  • 컨테이너 아티팩트를 생성하기 전에 마이그레이션 계획에서 v2kServiceManagertrue로 설정해야 합니다.

  • 새로운 services-config.yaml 파일을 검토하고 초기화 서비스를 수정해야 합니다. services-config.yaml 사용을 참조하세요.

마이그레이션을 수행하려면 다음 안내를 따르세요.

  1. Migrate to Containers 버전 1.15.0을 설치합니다.

  2. 기존 런타임과 마찬가지로 마이그레이션 소스를 추가하고 마이그레이션을 만듭니다.

  3. 필요에 따라 마이그레이션 계획을 맞춤설정합니다.

    1. 마이그레이션 계획을 다운로드합니다. 마이그레이션 계획은 AppXGenerateArtifactsFlow로 표시됩니다.

      예를 들어 이름이 'my-migration'인 마이그레이션의 경우 다음을 실행합니다.

      migctl migration get my-migration
    2. 다운로드한 마이그레이션 계획 my-migration.yaml을 텍스트 편집기에서 엽니다.

    3. 향상된 Linux 서비스 관리자를 확인합니다. v2kServiceManager 플래그는 기본적으로 true로 설정됩니다. 하지만 Migrate to Containers에서 서비스 관리자로 지원되지 않는 시스템 서비스를 감지하면 알림이 표시되고 v2kServiceManager 플래그가 false로 설정됩니다. 플래그가 false로 설정되었으면 마이그레이션에 서비스를 지원하는 기존 런타임이 사용됩니다.

      다음 알림은 지원되지 않는 서비스와 함께 제공됩니다.

      Service is not supported by v2k service manager, therefore legacy runtime
      will be used instead of v2k service manager, and migrated workload would
      not fit running on Autopilot clusters of Cloudrun.

      지원되지 않는 서비스를 찾았으면 플래그를 수동으로 true로 설정할 수도 있습니다. 이 경우 생성된 이미지에 실행될 수 없는 지원되지 않는 서비스를 보관하도록 선택하거나 마이그레이션 계획에서 삭제하여 서비스를 제외시킬 수 있습니다.

      새 서비스 관리자를 사용 설정하려면 플래그를 true로 설정합니다.

      v2kServiceManager: true
    4. 마이그레이션 계획 맞춤설정의 설명대로 마이그레이션에 필요한 다른 맞춤설정을 수행합니다.

    5. 수정이 완료되면 수정된 파일을 저장합니다.

    6. 수정된 마이그레이션 계획을 업로드합니다.

      migctl migration update my-migration --main-config my-migration.yaml
  4. 기존 런타임과 마찬가지로 마이그레이션 아티팩트를 생성하고 검토합니다.

  5. services-config.yaml 파일을 수정하여 컨테이너의 초기화 속성을 구성합니다. 파일을 저장하고 변경사항을 적용해서 컨테이너 이미지를 다시 빌드합니다.

    자세한 내용은 services-config.yaml 사용을 참조하세요.

  6. kubectl을 사용하여 GKE Autopilot 클러스터에 컨테이너를 배포합니다.

    kubectl apply -f deployment_spec.yaml

예시: Autopilot 클러스터에 빠른 시작 컨테이너 배포

현재의 빠른 시작 가이드를 사용하여 간단한 웹 서버가 포함된 컨테이너를 마이그레이션한 후 Autopilot 클러스터에 배포합니다. 빠른 시작 프로세스에서 변경해야 하는 유일한 사항은 다음과 같습니다.

  1. 마이그레이션 계획을 검토하는 VM 마이그레이션의 3단계에서 마이그레이션 계획의 v2kServiceManagertrue로 설정한 다음 계획을 저장합니다.

     
    v2kServiceManager: true
  2. 마이그레이션된 워크로드 배포 섹션에서 컨테이너를 배포하기 전에 GKE Autopilot 클러스터를 만들고 연결합니다.

    1. GKE Autopilot 클러스터를 만듭니다.

      gcloud container clusters create-auto "CLUSTER_NAME"
      --project "PROJECT_NAME"  --region "REGION" --release-channel "regular"
      --subnetwork "projects/PROJECT_NAME/regions/us-central1/subnetworks/default"
    2. 클러스터에 연결합니다.

      gcloud container clusters get-credentials CLUSTER_NAME 
        --zone REGION --project PROJECT_NAME 
      
    3. 마이그레이션된 워크로드 배포 섹션의 설명대로 컨테이너를 배포합니다.

AppXGenerateArtifactsFlow CRD 변경사항

CRD 파일을 사용하여 마이그레이션을 제어하는 경우 AppXGenerateArtifactsFlow CRD를 수정하여 v2kServiceManagertrue로 설정합니다. CRD 파일을 사용하여 마이그레이션을 제어하는 방법에 대한 자세한 내용은 마이그레이션 계획 맞춤설정을 참조하세요.

다음 단계