배포 자동화
배포 자동화란 한 번의 클릭 혹은 명령어 입력을 통해 전체 배포 과정을 자동으로 진행하는 것을 뜻한다.
배포 자동화의 역할
- 수동적이고 반복적인 배포 과정을 자동화함으로써 시간이 절약된다.
- 전체 배포 과정을 매번 일관되게 진행하는 구조를 설계하여 휴먼 에러(Human Error)를 방지할 수 있다.
- 휴먼 에러란 사람이 수동적으로 배포 과정을 진행하는 중에 생기는 실수를 뜻한다.
- 이전의 배포과정과 비교해 특정 과정을 생략하거나 다르게 진행하여 오류가 발생하는 것이 휴먼 에러의 예로 볼 수 있다.
배포 자동화 파이프라인

배포에서 파이프라인이란 용어는 소스 코드의 관리부터 실제 서비스로의 배포 과정을 연결하는 구조를 뜻한다.
파이프라인은 전체 배포 과정을 여러 단계(Stages)로 분리한다.
각 단계는 파이프라인 안에서 순차적으로 실행되며, 단계마다 주어진 작업(Actions)을 수행한다.
배포 자동화 파이프라인을 여러 단계로 분리할 때, 대표적으로 쓰이는 세 가지 단계가 존재한다.
1. Source 단계
- Source 단계에서는 원격 저장소에 관리되고 있는 소스 코드에 변경 사항이 일어날 경우, 이를 감지하고 다음 단계로 전달하는 작업을 수행한다.
2. Build 단계
- Build 단계에서는 Source 단계에서 전달받은 코드를 컴파일, 빌드, 테스트하여 가공한다.
- 또한, Build 단계를 거쳐 생성된 결과물을 다음 단계로 전달하는 작업을 수행한다.
3. Deploy 단계
- Deploy 단계에서는 Build 단계로부터 전달받은 결과물을 실제 서비스에 반영하는 작업을 수행한다.
주의해야 할 점은 파이프라인의 단계는 상황과 필요에 따라 더 세분화되거나 간소화될 수 있다는 것이다.
AWS 개발자 도구
AWS에는 개발자 도구 섹션이 존재하고, 개발자 도구 섹션에서 제공하는 서비스를 활용하여 배포 자동화 파이프라인을 구축할 수 있다.

CodeCommit
Source 단계를 구성할 때 CodeCommit 서비스를 이용한다.
CodeCommit은 GitHub과 유사한 서비스를 제공하는 버전 관리 도구이다.
이는 GitHub와 비교했을 때 보안과 관련된 기능에 강점을 가진다. 소스 코드의 유출이 크게 작용하는 기업에서는 매우 중요한 요소이다.
- 다만 CodeCommit을 사용할 때는 과금 가능성을 고려해야 한다. 그런 이유로 사이드 프로젝트나 가볍게 작성한 소스 코드를 저장해야 할 경우엔 GitHub를 이용하는 것이 효과적이라고 볼 수 있다.
CodeBuild
Build 단계에서는 CodeBuild 서비스를 이용한다.
CodeBuild 서비스를 통해 유닛 테스트, 컴파일, 빌드와 같은 빌드 단계에서 필수적으로 실행되어야 할 작업을 명령어를 통해 실행할 수 있다.
CodeDeploy
Deploy 단계를 구성할 때는 기본적으로 다양한 서비스를 이용할 수 있다.
CodeDeploy 서비스를 이용하면 실행되고 있는 서버 애플리케이션에 실시간으로 변경 사항을 전달할 수 있다.
또한 S3 서비스를 통해 S3 버킷을 이용해 업로드된 정적 웹 사이트에 변경 사항을 실시간으로 전달하고 반영할 수 있다.
CodePipeline
각 단계를 연결하는 파이프라인을 구축할 때 CodePipeline 서비스를 이용한다.
'TIL' 카테고리의 다른 글
| TIL [CI/CD - 배포 전략] #23.04.25 (0) | 2023.04.25 |
|---|---|
| TIL [CI/CD - CI/CD Pipeline] #23.04.20 (0) | 2023.04.25 |
| TIL [XML, JSON, YAML] #23.04.11 (0) | 2023.04.11 |
| TIL [데이터베이스 - 문제 상황에 따른 해결책] #23.03.30 (0) | 2023.03.30 |
| TIL [데이터베이스 - 데이터베이스 기초] #23.03.29 (0) | 2023.03.29 |
