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 BalancingElastic Load Balancing에서 CodeDeploy Amazon EC2 배포에 대한 로드 밸런서 설정 단원을 참조하십시오.

참고

여러 배포 그룹과 단일 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 배포 그룹을 생성합니다.

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

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

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

Auto Scaling 확장 이벤트 중에 CodeDeploy는 애플리케이션 개정을 새 EC2 인스턴스에 배포하기 위해서 Auto Scaling 수명 주기 후크를 사용합니다. 수명 주기 후크는 Auto Scaling 확장 이벤트가 진행 중이며 CodeDeploy가 확장된 인스턴스에 개정을 배포해야 함을 CodeDeploy에 알립니다.

참고

이 섹션에서 ‘수명 주기 후크’와 ‘후크’라는 용어는 CodeDeploy와 Auto Scaling을 통합하는 데 사용되는 후크를 말합니다. 이 후크는 AppSpec 'hooks' 섹션에 설명된 후크와는 다릅니다.

수명 주기 후크는 어떻게 생성되고 설치되나요?

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

CodeDeploy가 수명 주기 후크를 추가한 뒤에 수명 주기 후크는 어떻게 사용되나요?

수명 주기 후크가 설치되면 확장 이벤트 중에 사용됩니다. 확장 이벤트는 다음과 같이 진행됩니다.

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

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

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

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

  5. 알림을 받으면 CodeDeploy는 메시지를 분석하고 일부 검증을 수행하여 가장 최근에 성공한 개정으로 새 EC2 인스턴스에 애플리케이션을 배포하기 시작합니다.

  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) 설정에 정의된 인스턴스 수를 충족하기 위해 필요한 경우 시작 절차를 다시 시작합니다.

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 사용 설명서수명 주기 후크 추가를 참조하세요.

배포 중 이벤트 확장

배포 진행 중 Amazon EC2 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 프로세스 처리에 대한 중요 공지를 참조하세요.

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 에이전트를 사용합니다.