Github Actions, AWS Codedeploy 배포 자동화(1)

최근 거의 3일 내내 매달렸던 배포 자동화에 드디어 성공했다.
다음번에 삽질을 최대한 줄이고자 간단하게나마 과정을 남겨두려고 한다.

이번 글에선 AWS 콘솔에서의 세팅

다음 글에선 실제 연동 과정을 포스팅한다.


준비물


  1. 배포할 프로젝트의 Git repository (Nodejs 웹 프로젝트를 기준으로 작성됨)

  2. AWS S3 버킷

  3. EC2 인스턴스(서버로 사용될)


전체적인 흐름


프로젝트를 Git에 커밋하고 서버에서 배포되기까지의 대략적인 흐름은 위와 같다.
(제대로 이해했다면)
내용상으론 되게 간단한데 각 단계마다 서로 연결하는 과정에서 애를 많이 먹었다.


1. EC2 에 IAM 역할 등록


IAM 이란? : Identity and Access Management 의 약자로 AWS 에서 제공하는 서비스들간의 접근 권한을 관리해주는 서비스이다.

위 흐름도를 보면 EC2 인스턴스에서 Codedeploy 서비스를 이용해 S3 에 접근하게 되는데, 따라서 Codedeploy, S3 두 서비스에 대한 접근 권한이 필요하다.
이제 직접 IAM 역할을 만들고, EC2 에 등록해보자.


1) 새 IAM 역할 만들기


AWS 에서 서비스 탭 -> IAM -> 역할 만들기


2) EC2 개체 선택


EC2 인스턴스에 등록할 IAM 를 만드는 것이므로 EC2 를 선택하고 넘어가자.


3) 정책 설정



S3 와 Codedeploy 에 대한 모든 권한을 얻어오자.


4) 태그 설정 - 필수x


없어도 무관하고, 생성 후에 수정할 수 있으니 건너뛰자.


5) 검토 및 생성


역할의 이름을 설정하고, 생성해주자.


6) 기존 인스턴스에 IAM 역할 등록


서버로 사용할 EC2 인스턴스에 IAM 역할을 등록해주자. (EC2가 없다면 만들어주자)



IAM 역할을 위에서 만든 역할로 바꿔주면 끝!
이제 EC2 에서 AWS S3, Codedeploy 에 접근할 수 있게 되었다!!


2. Codedeploy Agent 사용자 생성


AWS 를 처음 시작하게 되면 기본적으로 루트 사용자로 작업을 진행하게 되는데, AWS 에선 모든 작업에서의 루트 사용자 사용을 지양한다.
따라서 Codedeploy 작업을 할 새로운 사용자를 생성해 주는 것이 바람직하므로 새로 사용자를 생성하고, 위에서와 같이 IAM 역할을 부여해보자.


1) IAM 사용자 및 그룹 추가

AWS가 처음이라면 그룹이나 사용자 모두 아무것도 없을 것이다.
AWS 서비스 탭 -> IAM -> 사용자 로 들어가서 사용자를 새로 만들어주자.


사용자 이름을 지정해주고, 우리는 나중에 AWS CLI 를 사용할 것이므로 프로그래밍 방식 엑세스에 체크하자.


IAM 권한을 사용자에게 직접 부여하거나 그룹에 부여한 뒤 사용자를 추가하는 등 여러가지 방법이 있을 수 있는데, 이 글에선 그룹에 권한을 부여하고 사용자를 추가하는 방식으로 했다.


2) 그룹에 정책 설정


EC2 에 정책을 설정할 때와 마찬가지로 S3, Codedeploy 모두 FullAccess 로 설정해주자.


3) 엑세스 키 받기 - 주의!!

사용자가 정상적으로 만들어지면 위와 같이 엑세스 키, 비밀 엑세스 키를 받으라는 창이 뜨는데, 
주의할 점은 이 페이지에서 두 키를 다운로드 받거나 복사하지 않으면 다신 키를 볼 수 없다!
그러니 꼭 안전한 곳에 저장해두자.
물론 이전 키를 삭제하고 다시 받을 수는 있다.


새로 만들어진 사용자와 부여받은 정책을 확인할 수 있다.


3. Codedeploy 생성 및 역할 등록



이제 Codedeploy 서비스를 이용할 사용자가 만들어졌으니 다음은 Codedeploy Application을 만들 차례이다.
 

1) Codedeploy 역할 생성

Codedeploy Application 을 만들기 전에 앞서 했던 것과 같이 Codedeploy 용 IAM 역할을 만들어 줘야 한다.
Codedeploy 용 역할을 선택한다.



Codedeploy 용 역할은 하나밖에 없으므로 자동 선택된다.


이름을 지정해주고 만들어주자.


2) Codedeploy Application 및 배포 그룹 생성

AWS 서비스 탭 -> CodeDeploy -> 애플리케이션 -> 애플리케이션 생성 을 눌러 Codedeploy Application을 만들자.


이름을 정하고, 컴퓨팅 플랫폼은 EC2/온프레미스로 선택


Codedeploy Application을 만들었으면 배포 그룹을 지정해 주어야 한다.
이후에 Github Actions와의 연동을 끝내면 Commit 을 감지하고 해당 그룹으로 자동으로 배포를 수행하게 된다.


배포 그룹의 이름을 정하고, 앞에서 만들어둔 IAM 역할을 부여하자.



EC2 인스턴스를 태그 값으로 고유하게 식별해 등록할 수 있다. 
EC2 인스턴스의 태그가 없다면 태그를 새로 등록해주자.


배포의 성공 여부를 정하는 규칙을 지정해 주어야 한다.
여러 개의 배포 대상이 있을 때, 지정한 일정 비율 이상이 배포되었다면 성공, 아니라면 실패로 판단한다.
우리는 EC2 인스턴스 하나밖에 없으니 AllAtOnce 를 선택해주자.


로드밸런서를 사용하지 않으므로 로드 밸런싱은 꺼주자.


+ S3 버킷 생성

이제 남은 건 버전별로 프로젝트가 저장될 S3 버킷인데, 정말 간단히 만들면 된다.
AWS 서비스 탭 -> S3 -> 버킷 만들기 -> 이름 지정 -> 다음 -> 다음 -> 다음...
배포 자동화를 해보는게 목표이므로 아무 설정도 지정하지 않고 만들었다.


여기까지 진행했다면 이제 지긋지긋한 AWS 콘솔에서의 작업은 모두 끝났다.
다음 글에서 Github 와 S3 , S3 와 EC2 를 연결하여 프로젝트가 자동으로 배포되게 해보자!

댓글

이 블로그의 인기 게시물

HTML - input file 버튼 꾸미기

HTML - 이미지 미리보기(jQuery 없이)

BOJ - DNA 유사도(2612)