Amazon EC2 Auto Scaling과 CodeDeploy 통합 - AWS CodeDeploy

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

Amazon EC2 Auto Scaling과 CodeDeploy 통합

CodeDeploy는 정의된 조건에 따라 Amazon EC2 인스턴스를 자동으로 시작할 수 있는 AWS 서비스인 Amazon EC2 Auto Scaling을 지원합니다. 이러한 조건에는 지정된 시간 간격에서 CPU 사용률, 디스크 읽기 또는 쓰기, 인바운드 또는 아웃바운드 네트워크 트래픽에 대해 초과되는 제한이 포함될 수 있습니다. Amazon EC2 Auto Scaling은 더 이상 필요하지 않은 경우 해당 인스턴스를 종료합니다. 자세한 내용은 Amazon EC2 Auto Scaling 사용 설명서Amazon EC2 Auto Scaling이란?을 참조하세요.

새 Amazon EC2 인스턴스가 Amazon EC2 Auto Scaling 그룹의 일부로 시작되면 CodeDeploy에서는 개정을 새 인스턴스로 자동 배포할 수 있습니다. 또한 Elastic Load Balancing 로드 밸런서에 등록된 Amazon EC2 Auto Scaling 인스턴스를 사용하여 CodeDeploy에서 배포를 조정할 수도 있습니다. 자세한 정보는 Integrating CodeDeploy with Elastic Load Balancing CodeDeploy Amazon EC2 배포를 위한 Elastic Load Balancing에서 로드 밸런서를 설정합니다. 섹션을 참조하십시오.

참고

여러 배포 그룹과 단일 Amazon EC2 Auto Scaling 그룹을 연결하는 경우 문제가 발생할 수 있습니다. 한 개의 배포에 실패하면 예를 들어, 인스턴스가 종료되기 시작하지만 실행 중인 다른 배포는 시간 초과까지 한 시간 가량 걸릴 수 있습니다. 자세한 내용은 단일 Amazon EC2 Auto Scaling 그룹으로 여러 배포 그룹 연결 피하기세부 정보: CodeDeploy 및 Amazon EC2 Auto Scaling 통합을 참조하세요.

Amazon EC2 Auto Scaling 그룹에 CodeDeploy 애플리케이션 배포

Amazon EC2 Auto Scaling 그룹에 CodeDeploy 애플리케이션 개정 버전을 배포하려면 다음을 수행하세요.

  1. Amazon EC2 Auto Scaling 그룹이 Amazon S3와 연동할 수 있도록 허용하는 IAM 인스턴스 프로파일을 만들거나 찾습니다. 자세한 내용은 4단계: Amazon EC2 인스턴스에 대한 IAM 인스턴스 프로파일 만들기 섹션을 참조하세요.

    참고

    CodeDeploy를 사용하여 GitHub 리포지토리에서 Amazon EC2 Auto Scaling 그룹으로 개정을 배포할 수도 있습니다. Amazon EC2 인스턴스는 IAM 인스턴스 프로파일을 계속 필요로 하지만, 이 프로파일에는 GitHub 리포지토리에서 배포하기 위한 추가 권한이 필요하지 않습니다.

  2. 시작 구성이나 템플릿에서 IAM 인스턴스 프로파일을 지정하여 Amazon EC2 Auto Scaling 그룹을 생성하거나 사용합니다. 자세한 내용은 Amazon EC2 인스턴스에서 실행되는 애플리케이션의 IAM 역할을 참조하세요.

  3. CodeDeploy가 Amazon EC2 Auto Scaling 그룹이 포함된 배포 그룹을 생성하도록 허용하는 서비스 역할을 만들거나 찾습니다.

  4. Amazon EC2 Auto Scaling 그룹 이름, 서비스 역할 및 기타 몇 가지 옵션을 지정하여 CodeDeploy로 배포 그룹을 생성합니다. 자세한 내용은 인 플레이스(in-place) 배포에 사용할 수 있는 배포 그룹 만들기(콘솔) 또는 인 플레이스(in-place) 배포에 사용할 수 있는 배포 그룹 만들기(콘솔) 단원을 참조하세요.

  5. CodeDeploy를 사용하여 Amazon EC2 Auto Scaling 그룹이 포함된 배포 그룹에 수정 버전을 배포합니다.

자세한 내용은 튜토리얼: CodeDeploy를 사용하여 Auto Scaling 그룹에 애플리케이션 배포 섹션을 참조하세요.

Auto Scaling 확장 이벤트 중 종료 배포 활성화

종료 배포는 Auto Scaling 스케일 인 이벤트가 발생하면 자동으로 활성화되는 CodeDeploy 배포의 한 유형입니다. CodeDeploy는 Auto Scaling 서비스가 인스턴스를 종료하기 직전에 종료 배포를 수행합니다. 종료 배포 중에는 CodeDeploy는 아무것도 배포하지 않습니다. 대신 수명 주기 이벤트를 생성하며, 이를 자체 스크립트에 연결하여 사용자 지정 종료 기능을 활성화할 수 있습니다. 예를 들어, 인스턴스가 종료되기 전에 애플리케이션을 정상적으로 종료하는 스크립트에 ApplicationStop 수명 주기 이벤트를 연결할 수 있습니다.

종료 배포 중에 CodeDeploy가 생성하는 수명 주기 이벤트 목록은 수수명 주기 이벤트 후크 가용성을 참조하세요.

종료 배포가 어떤 이유로든 실패하면 CodeDeploy는 인스턴스 종료를 계속 진행하도록 허용합니다. 즉, CodeDeploy가 수명 주기 이벤트의 전체 집합(또는 일부)을 완료까지 실행하지 않았더라도 인스턴스가 종료됩니다.

종료 배포를 활성화하지 않으면 Auto Scaling 서비스는 스케일인 이벤트가 발생할 때 Amazon EC2 인스턴스를 계속 종료하지만 CodeDeploy는 수명 주기 이벤트를 생성하지 않습니다.

참고

종료 배포를 사용하도록 설정했는지 여부와 관계없이 자동 확장 서비스가 CodeDeploy 배포가 진행 중인 동안 Amazon EC2 인스턴스를 종료하면 자동 확장 및 CodeDeploy 서비스에서 생성된 수명 주기 이벤트 간에 경합 조건이 발생할 수 있습니다. 예를 들어, Auto Scaling 서비스에 의해 생성된 Terminating 수명 주기 이벤트가 CodeDeploy 배포에 의해 생성된 ApplicationStart 이벤트보다 우선할 수 있습니다. 이 시나리오에서는 Amazon EC2 인스턴스 종료 또는 CodeDeploy 배포에 실패가 발생할 수 있습니다.

CodeDeploy가 종료 배포를 수행하도록 하려면 다음을 수행하세요.

종료 후크가 설치되면 다음과 같이 스케일 인(종료) 이벤트가 전개됩니다.

  1. Auto Scaling 서비스(또는 간단히 자동 확장)는 스케일 인 이벤트가 발생해야 한다고 판단하고 EC2 인스턴스를 종료하기 위해 EC2 서비스에 연락합니다.

  2. EC2 서비스가 EC2 인스턴스를 종료하기 시작합니다. 인스턴스는 Terminating 상태가 되고 그 다음엔 Terminating:Wait 상태가 됩니다.

  3. Terminating:Wait 동안 Auto Scaling은 CodeDeploy에서 설치된 종료 후크를 포함한 Auto Scaling 그룹에 연결된 모든 수명 주기 후크를 실행합니다.

  4. 종료 후크가 알림을 CodeDeploy에 의해 폴링된 Amazon SQS 대기열로 보냅니다.

  5. 알림을 받으면 CodeDeploy는 메시지를 구문 분석하고 몇 가지 유효성 검사를 수행한 후 종료 배포를 수행합니다.

  6. 종료 배포가 실행되는 동안 CodeDeploy 5분마다 하트비트를 Auto Scaling으로 전송하여 인스턴스가 여전히 작업 중임을 알립니다.

  7. 지금까지 EC2 인스턴스는 여전히 Terminating:Wait 상태(또는 Auto Scaling group 워밍 풀을 활성화한 경우 Warmed:Pending:Wait 상태일 수 있음)에 있습니다.

  8. 배포가 완료되면 종료 배포의 성공 또는 실패 여부에 관계없이 Auto Scaling에 EC2 종료 프로세스를 계속 진행하도록 CodeDeploy가 표시합니다.

Amazon EC2 Auto Scaling에서 CodeDeploy를 사용하는 방식

Auto Scaling 그룹을 포함하도록 CodeDeploy 배포 그룹을 생성하거나 업데이트하면 CodeDeploy는 CodeDeploy 서비스 역할을 사용하여 Auto Scaling 그룹에 액세스한 다음 Auto Scaling 수명 주기 후크를 Auto Scaling 그룹에 설치합니다.

참고

Auto Scaling 수명 주기 후크는 CodeDeploy에 의해 생성되고 이 안내서의 AppSpec '후크' 섹션에 설명된 수명 주기 이벤트(수명 주기 이벤트 후크라고도 함)와는 다릅니다.

CodeDeploy가 설치하는 Auto Scaling 수명 주기 훅은 다음과 같습니다.

  • 시작 후크 - 이 후크는 Auto Scaling 스케일 아웃 이벤트가 진행 중이며 CodeDeploy가 시작 배포를 시작해야 한다는 것을 CodeDeploy에 알립니다.

    시작 배포 중에 CodeDeploy는 다음을 수행합니다.

    • 애플리케이션의 개정 버전을 스케일 아웃 인스턴스에 배포합니다.

    • 배포 진행 상황을 나타내는 수명 주기 이벤트를 생성합니다. 이러한 수명 주기 이벤트를 자체 스크립트에 연결하여 사용자 지정 시작 기능을 활성화할 수 있습니다. 자세한 내용은 수명 주기 이벤트 후크 가용성 표를 참조하세요.

    시작 후크 및 관련 시작 배포는 항상 활성화되어 있으며 끌 수 없습니다.

  • 종료 후크 - 이 선택적 후크는 Auto Scaling 스케일 인 이벤트가 진행 중이며 CodeDeploy가 종료 배포를 시작해야 함을 CodeDeploy에 알립니다.

    종료 배포 중에 CodeDeploy는 수명 주기 이벤트를 생성하여 인스턴스 종료의 진행 상황을 나타냅니다. 자세한 내용은 Auto Scaling 확장 이벤트 중 종료 배포 활성화 섹션을 참조하세요.

CodeDeploy가 수명 주기 훅을 설치한 후에는 어떻게 사용되나요?

시작 및 종료 수명 주기 후크가 설치되면 Auto Scaling 그룹 스케일 아웃 및 스케일 인 이벤트 중에 각각 CodeDeploy에서 사용됩니다.

스케일 아웃(시작) 이벤트는 다음과 같이 전개됩니다.

  1. Auto Scaling 서비스(또는 단순히 Auto Scaling)가 확장 이벤트가 발생해야 한다고 판단하면 EC2 서비스에 연결하여 새 EC2 인스턴스를 시작합니다.

  2. EC2 서비스는 새 EC2 인스턴스를 시작합니다. 인스턴스는 Pending 상태가 되고 그 다음엔 Pending:Wait 상태가 됩니다.

  3. Pending:Wait 동안 Auto Scaling은 Auto Scaling 그룹에 연결된 모든 수명 주기 후크를 실행하며, 여기에는 CodeDeploy에 의해 설치된 런치 후크가 포함됩니다.

  4. 시작 후크는 CodeDeploy가 폴링하는 Amazon SQS 대기열에 알림을 보냅니다.

  5. 알림을 받으면 CodeDeploy는 메시지를 구문 분석하고 몇 가지 유효성 검사를 수행한 후 시작 배포를 시작합니다.

  6. 시작 배포가 실행되는 동안 CodeDeploy 5분마다 하트비트를 Auto Scaling으로 전송하여 인스턴스가 여전히 작업 중임을 알립니다.

  7. 지금까지 EC2 인스턴스는 여전히 Pending:Wait 상태입니다.

  8. 배포가 완료되면 CodeDeploy는 배포 성공 또는 실패 여부에 따라 Auto Scaling에 CONTINUE 또는 ABANDON EC2 시작 프로세스를 알립니다.

    • CodeDeploy가 CONTINUE를 알리면 Auto Scaling은 시작 프로세스를 이어가서 다른 후크가 완료될 때까지 기다리거나 인스턴스를 Pending:Proceed 상태로 설정한 다음 InService 상태로 설정합니다.

    • CodeDeploy가 ABANDON을 알리면 Auto Scaling은 EC2 인스턴스를 종료하고 Auto Scaling의 원하는 용량(Desired Capacity) 설정에 정의된 인스턴스 수를 충족하기 위해 필요한 경우 시작 절차를 다시 시작합니다.

스케일 인(종료) 이벤트는 다음과 같이 전개됩니다.

Auto Scaling 확장 이벤트 중 종료 배포 활성화를 참조하세요.

CodeDeploy가 Amazon EC2 Auto Scaling 그룹에 이름을 지정하는 방법

EC2/온프레미스 컴퓨팅 플랫폼을 기반으로 한 블루/그린 배포 과정에서는 인스턴스를 대체(그린) 환경에 추가하는 옵션이 두 가지입니다.

  • 이미 존재하거나, 혹은 수동으로 생성한 인스턴스를 사용합니다.

  • 지정한 Amazon EC2 Auto Scaling 그룹의 설정을 사용하여 새 Amazon EC2 Auto Scaling 그룹에서 인스턴스를 정의하고 생성합니다.

두 번째 옵션을 선택하면 CodeDeploy는 새로운 Amazon EC2 Auto Scaling 그룹을 프로비저닝합니다. 그룹 이름을 지정할 때 사용하는 규칙은 다음과 같습니다.

CodeDeploy_deployment_group_name_deployment_id

예를 들어 ID가 10인 배포를 통해 alpha-deployments라는 이름의 배포 그룹을 배포하는 경우 프로비저닝되는 Amazon EC2 Auto Scaling 그룹은 CodeDeploy_alpha-deployments_10이라는 이름으로 지정됩니다. 자세한 내용은 EC2/온프레미스 블루/그린 배포에 사용할 수 있는 배포 그룹 만들기(콘솔)GreenFleetProvisioningOption 단원을 참조하세요.

사용자 지정 수명 주기 후크의 실행 순서

CodeDeploy에서 배포하는 Amazon EC2 Auto Scaling 그룹에 고유한 수명 주기 후크를 추가할 수 있습니다. 그러나 사용자 지정 수명 주기 후크 이벤트가 실행되는 순서는 CodeDeploy 기본 배포 수명 주기 이벤트를 기준으로 미리 결정할 수 없습니다. 예를 들어 ReadyForSoftwareInstall이라는 사용자 지정 수명 주기 후크를 Amazon EC2 Auto Scaling 그룹에 추가하면 이 후크가 첫 번째 CodeDeploy 기본 배포 수명 주기 이벤트 이전에 실행될지 또는 마지막 이벤트 이후에 실행될지 사전에 알 수 없습니다.

사용자 지정 수명 주기 후크를 Amazon EC2 Auto Scaling 그룹에 추가하는 방법을 알아보려면 Amazon EC2 Auto Scaling 사용 설명서수명 주기 후크 추가를 참조하세요.

배포 중 이벤트 확장

배포가 진행되는 동안 Auto Scaling 스케일 아웃 이벤트가 발생하면 새 인스턴스는 최신 애플리케이션 개정 버전이 아닌 이전에 배포된 애플리케이션 개정 버전으로 업데이트됩니다. 배포에 성공하면 이전 인스턴스와 새로 확장된 인스턴스가 다른 애플리케이션 개정을 호스팅합니다. 이전 개정 버전의 인스턴스를 최신 상태로 유지하기 위해 CodeDeploy는 자동으로 후속 배포를 시작하여(첫 번째 배포 직후에) 오래된 인스턴스를 업데이트합니다. 오래된 EC2 인스턴스가 이전 버전으로 유지되도록 이 기본 동작을 변경하려면 Automatic updates to outdated instances 섹션을 참조하세요.

배포가 진행되는 동안 Amazon EC2 Auto Scaling 확장 프로세스를 일시 중단하려면 CodeDeploy를 통해 로드 밸런싱에 사용되는 common_functions.sh 스크립트 설정을 통해 수행합니다. HANDLE_PROCS=true이면 배포 프로세스 중 다음 Auto Scaling 이벤트가 자동으로 일시 중단됩니다.

  • AZRebalance

  • AlarmNotification

  • ScheduledActions

  • ReplaceUnhealthy

중요

CodeDeployDefault.OneAtATime 배포 구성만 이 기능을 지원합니다.

Amazon EC2 Auto Scaling을 사용할 때 HANDLE_PROCS=true를 사용하여 배포 문제를 방지하려면 GitHub에 있는 aws-codedeploy-samples에서 AutoScaling 프로세스 처리에 대한 중요 공지를 참조하세요.

배포 중에 스케일 인 이벤트

해당 Auto Scaling 그룹에서 CodeDeploy 배포가 진행 중인 동안 Auto Scaling 그룹이 확장을 시작하면 종료 프로세스(CodeDeploy 종료 배포 수명 주기 이벤트 포함)와 종료 인스턴스의 다른 CodeDeploy 수명 주기 이벤트 간에 경합 조건이 발생할 수 있습니다. 모든 CodeDeploy 수명 주기 이벤트가 완료되기 전에 인스턴스가 종료되면 해당 특정 인스턴스에 대한 배포가 실패할 수 있습니다. 또한 배포 구성에서 최소 정상 호스트 설정을 어떻게 설정했는지에 따라 전체 CodeDeploy 배포가 실패할 수도 있고 실패하지 않을 수도 있습니다.

AWS CloudFormation cfn-init 스크립트의 이벤트 순서

새로 프로비저닝된 Linux 기반 인스턴스에서 cfn-init(또는 cloud-init)를 사용하여 스크립트를 실행하는 경우 인스턴스 시작 후 발생하는 이벤트 순서를 엄격하게 제어하지 않으면 배포에 실패할 수 있습니다.

순서는 다음과 같아야 합니다.

  1. 새로 프로비저닝된 인스턴스가 시작합니다.

  2. 모든 cfn-init 부트스트래핑 스크립트가 완료될 때까지 실행됩니다.

  3. CodeDeploy 에이전트가 시작됩니다.

  4. 최신 애플리케이션 개정이 인스턴스에 배포됩니다.

이벤트 순서를 신중하게 제어하지 않으면 모든 스크립트의 실행이 완료되기 전에 CodeDeploy 에이전트가 배포를 시작할 수 있습니다.

이벤트 순서를 제어하려면 다음 모범 사례 중 하나를 사용합니다.

  • cfn-init 스크립트를 통해 CodeDeploy 에이전트를 설치합니다. 이때 이 스크립트를 다른 모든 스크립트 뒤에 배치합니다.

  • 사용자 정의 AMI에 CodeDeploy 에이전트를 포함하고 cfn-init 스크립트를 사용해 시작합니다. 이때 이 스크립트를 다른 모든 스크립트 뒤에 배치합니다.

cfn-init 사용에 대한 자세한 내용은 AWS CloudFormation 사용 설명서cfn-init를 참조하세요.

CodeDeploy 및 Amazon EC2 Auto Scaling에서 사용자 지정 AMI 사용

새 Amazon EC2 인스턴스를 Amazon EC2 Auto Scaling 그룹에서 시작하는 경우 사용할 기본 AMI를 지정하는 데 다음 두 가지 옵션이 있습니다.

  • CodeDeploy 에이전트가 이미 설치된 기본 사용자 지정 AMI를 지정할 수 있습니다. 에이전트가 이미 설치되어 있으므로 이 옵션은 다른 옵션보다 훨씬 빨리 새 Amazon EC2 인스턴스를 시작합니다. 그러나 이 옵션은 특히 CodeDeploy 에이전트가 오래된 경우 Amazon EC2 인스턴스의 초기 배포에 실패할 가능성이 더 큽니다. 이 옵션을 선택하면 기본 사용자 지정 AMI에서 CodeDeploy 에이전트를 정기적으로 업데이트하는 것이 좋습니다.

  • CodeDeploy 에이전트가 설치되지 않은 기본 AMI를 지정하고 각각의 새 인스턴스가 Amazon EC2 Auto Scaling 그룹에서 시작될 때 이 에이전트가 설치되도록 할 수 있습니다. 이 옵션은 다른 옵션보다 새 Amazon EC2 인스턴스의 시작 속도가 훨씬 느리긴 하지만 초기 인스턴스 배포에 성공할 가능성이 더 큽니다. 이 옵션은 최신 버전의 CodeDeploy 에이전트를 사용합니다.