GitLab CI/CD에서 AWS로 배포
GitLab이 제공하는 Docker 이미지와 CloudFormation 템플릿을 사용하여 GitLab CI/CD에서 ECS 및 EC2를 포함한 AWS에 애플리케이션을 배포하는 방법
GitLab은 AWS에 배포하는 데 필요한 라이브러리와 도구가 포함된 Docker 이미지를 제공합니다. CI/CD 파이프라인에서 이러한 이미지를 참조할 수 있습니다. GitLab.com을 사용하고 Amazon Elastic Container Service (ECS)에 배포하는 경우 ECS에 배포하기 에 대한 내용을 읽어보세요. Note 직접 배포를 구성하고 AWS 자격 증명만 가져와야 하는 경우 ID 토큰 및 OpenID Connect 를 사용하는 것을 고려하세요. ID 토큰은 CI/CD 변수에 자격 증명을 저장하는 것보다 더 안전하지만 이 페이지의 지침에서는 작동하지 않습니다. AWS로 GitLab 인증 # GitLab CI/CD를 사용하여 AWS에 연결하려면 인증해야 합니다. 인증을 설정한 후 배포할 CI/CD를 구성할 수 있습니다. AWS 계정에 로그인합니다. IAM 사용자 를 생성합니다. 사용자를 선택하여 세부 정보에 액세스합니다. Security credentials > Create a new access key 로 이동합니다. Access key ID 와 Secret access key 를 기록합니다. GitLab 프로젝트에서 Settings > CI/CD 로 이동합니다. 다음 CI/CD 변수 를 설정합니다: 환경 변수 이름 값 AWS_ACCESS_KEY_ID 액세스 키 ID. AWS_SECRET_ACCESS_KEY 비밀 액세스 키. AWS_DEFAULT_REGION 리전 코드. 사용하려는 AWS 서비스가 선택한 리전에서 사용 가능한지 확인하는 것이 좋습니다. 변수는 기본적으로 보호됩니다 . 보호되지 않은 브랜치 또는 태그에서 GitLab CI/CD를 사용하려면 Protect variable 체크박스를 지웁니다. 이미지를 사용하여 AWS 명령 실행 # 이미지에 AWS Command Line Interface 가 포함된 경우 프로젝트의 .gitlab-ci.yml 파일에서 이미지를 참조할 수 있습니다. 그런 다음 CI/CD job에서 aws 명령을 실행할 수 있습니다. 예를 들어: deploy: stage: deploy image: registry.gitlab.com/gitlab-org/cloud-deploy/aws-base:latest script: - aws s3 ... - aws create-deployment ... environment: production GitLab은 AWS CLI가 포함된 Docker 이미지를 제공합니다: 이미지는 GitLab 컨테이너 레지스트리에 호스팅됩니다. 최신 이미지는 registry.gitlab.com/gitlab-org/cloud-deploy/aws-base:latest 입니다. 이미지는 GitLab 저장소에 저장됩니다 . 또는 Amazon Elastic Container Registry (ECR) 이미지를 사용할 수 있습니다. ECR 저장소에 이미지를 푸시하는 방법 을 알아보세요. 타사 레지스트리의 이미지도 사용할 수 있습니다. ECS에 애플리케이션 배포 # Amazon ECS 클러스터에
