배포 자동화
한 번의 클릭 혹은 명령어 입력을 통해 전체 배포 과정을 자동으로 진행하는 것
이유:
- 수동적이고 반복적인 배포 과정을 자동화함으로써 시간이 절약
- 휴먼 에러(Human Error)를 방지
배포 자동화 파이프라인
data:image/s3,"s3://crabby-images/3a3a7/3a3a7154b024184916c905c46f8dac86713117be" alt=""
배포에서 파이프라인(Pipeline) : 용어는 소스 코드의 관리부터 실제 서비스로의 배포 과정을 연결하는 구조를 뜻함
- Source 단계: Source 단계에서는 원격 저장소에 관리되고 있는 소스 코드에 변경 사항이 일어날 경우, 이를 감지하고 다음 단계로 전달하는 작업을 수행
- Build 단계: Build 단계에서는 Source 단계에서 전달받은 코드를 컴파일, 빌드, 테스트하여 가공, Build 단계를 거쳐 생성된 결과물을 다음 단계로 전달하는 작업을 수행
- Deploy 단계: Deploy 단계에서는 Build 단계로부터 전달받은 결과물을 실제 서비스에 반영하는 작업을 수행
주의할 사항
- 파이프라인의 단계는 상황과 필요에 따라 더 세분화되거나 간소화될 수 있음
AWS 개발자 도구
CodeCommit
-
Source 단계를 구성할 때 CodeCommit 서비스를 이용
-
GitHub과 유사한 서비스를 제공하는 버전 관리 도구
-
CodeCommit 서비스는 보안과 관련된 기능에 강점
-
가볍게 작성한 소스 코드를 저장해야 할 경우에는 GitHub을 이용하는 것이 효과적
CodeBuild
-
Build 단계에서는 CodeBuild 서비스를 이용
-
유닛 테스트, 컴파일, 빌드와 같은 빌드 단계에서 필수적으로 실행되어야 할 작업을 명령어를 통해 실행
CodeDeploy
CodePipeline
- 각 단계를 연결하는 파이프라인을 구축할 때 CodePipeline 서비스를 이용
클라이언트 배포 파이프라인
data:image/s3,"s3://crabby-images/09e49/09e49f4bac8da10faee37a2e5f3e63d62fc29391" alt=""
1. buildspec.yml 작성
data:image/s3,"s3://crabby-images/df255/df255b51e22308a8ff7b07d798e87d5153b0de45" alt=""
2. 파이프라인 구성
2-1. 검색 창에 CodePipeline 클릭 후 파이프라인 생성 클릭
data:image/s3,"s3://crabby-images/0218d/0218d7e6c6c0006c3b4ea29e2360ab075bd4c937" alt=""
2-2. 이름과 서비스 역할에서 새 서비스 역할 클릭 후 다음 클릭
data:image/s3,"s3://crabby-images/4571b/4571bc551b967f6f5e83ce338653a2d2f905571a" alt=""
3. 소스 공급자를 클릭해서 GitHub를 선택(build 할 데이터가 있는 곳을 선택하면 됨)
만약 GitHub를 선택했으면, GitHub 연결을 클릭 > 내 GitHub의 리파지토리와 연결을 위해서
data:image/s3,"s3://crabby-images/c75aa/c75aa652b1d64f7169fbf9fee4467e18dd420ce0" alt=""
4. 이름은 아무거나 입력
data:image/s3,"s3://crabby-images/4a1e8/4a1e85c448e3839955e6f62ddeac77c7df6bd042" alt=""
5. github에 연결 클릭 하면 GitHub 앱의 새 앱 설치 클릭
data:image/s3,"s3://crabby-images/9119a/9119ac242e6fc3e15cb757f9cb2c36f2798b114e" alt=""
6. aws와 연결할 github 아이디 선택
data:image/s3,"s3://crabby-images/6c84e/6c84ed032254e7ac55024154215aad59f210a20e" alt=""
7. 실행할 소스 코드가 있는 자신의 리파지토리 선택
install 버튼 클릭
data:image/s3,"s3://crabby-images/45ea5/45ea5a8b5ab655871d2d7c88b3e584243b6cef1f" alt=""
8. 생성한 GitHub 앱 선택 후 연결 클릭
data:image/s3,"s3://crabby-images/c398a/c398a4c2db63df6a5fe88b29d48ce946923af388" alt=""
9. 리파지토리 이름과 , 해당 리파지토리의 main 브랜치를 선택한 뒤 다음 버튼 클릭
data:image/s3,"s3://crabby-images/f12c4/f12c40176ff1312920e8ae55c842ff9ca4c50c5c" alt=""
10. 빌드 단계에서 codeBuild 프로젝트 생성
소스 단계를 통해 전달받은 코드를 테스트하거나 빌드하여 배포 단계로 전달하는 역할
data:image/s3,"s3://crabby-images/5d128/5d12840359fb7333e0905e63b8205b9c9bfae08b" alt=""
11. 빌드 프로젝트 이름은 마음대로 지음
data:image/s3,"s3://crabby-images/60fd0/60fd0dda2fbb338d183bd81c3d4a11c719efcb06" alt=""
12. Ubuntu 운영체제를 선택
다른 운영체제를 선택할 시 yml 파일이 오류를 일으킬 수 있음
data:image/s3,"s3://crabby-images/db474/db474d50cdfaab0999fdf7172c22a1091942c7e0" alt=""
13. 로그 파일을 저장하는 서비스로 CloudWatch 혹은 S3를 이용
S3에는 정적 웹 호스팅을 위한 버킷이 이미 생성
버킷의 수가 많아지면 과금이 될 가능성이 다소 커질 수 있기에, CloudWatch 서비스를 빌드 출력 로그 저장을 위한 서비스로 선택하여 리소스를 분산
data:image/s3,"s3://crabby-images/758ca/758ca39bf883fe5d3556eebc89ac26860f16bf52" alt=""
14. 다음 클릭
data:image/s3,"s3://crabby-images/e3ec9/e3ec988df122738e25457e486852ebf964968b06" alt=""
15. 최종적으로 만들어진 결과물을 전달 및 반영할 위치를 선택, client이므로 s3를 선택
data:image/s3,"s3://crabby-images/a4a1a/a4a1a5234b5576075e8b2b888e7d8951c834b9b8" alt=""
16. s3를 만들었을 때 사용한 버킷 이름을 선택
data:image/s3,"s3://crabby-images/dae35/dae35567efcbba35af60879a7c6c7c479b528c1b" alt=""
17. 검토한 후 다 맞다면 파이프라인 생성 클릭
data:image/s3,"s3://crabby-images/c6bcd/c6bcdf4074c1e18e99c4d6d5d05ee3b241e13bc7" alt=""
결과
data:image/s3,"s3://crabby-images/88f26/88f2696c047c0406cc629e024abeb5c4d4a5945e" alt=""
배포가 성공하는 것을 확인할 수 있다