CodeCommit은 설정을 끝냈고 Deploy를 하는데 서버에 소스 그대로 배포할 것이므로 EC2를 하나 추가한다. 이 때, EC2에 codeDeploy Agent를 설치하도록 Set한다. EC2에서 CodeCommit에 접근해야하므로 관련 역할도 추가한다.
IAM > 역할 > 역할 만들기 . 신뢰할 수 있는 엔터티 유형 : AWS 서비스 선택 . 사용사례 : EC2 선택 하고 다음버튼 클릭 . 권한정책 : AmazonEC2RoleforAWSCodeDeploy 검색하여 check 한 뒤 다음. . 역할이름 : EC2InstanceRole
EC2 > 인스턴스 시작
1. AMI : Amazon Linux 2 AMI 를 선택 2. 인스턴스 유형 : t2.micro 3. 인스턴스 구성 . 퍼블릭 IP 자동할당 : 활성화 . IAM 역할선택 : EC2InstanceRole (위에서 생성한 Role ) . 고급 세부 정보 [Advanced Detail] - 사용자 데이터(User Data) : 텍스트로 선택 - TextArea에 아래내용 복사. agent를 다운받아 설치하는 것이므로 문구 그대로 입력하면 됨.(ubuntu에서도 같은지는 모르겠음)
4. 스토리지 추가 : "다음"클릭 5. 태그 추가 : 인스턴스에 Tag를 지정해야 목록에서 구별이 잘 됨. Key : Name Value : EC2forCodePipeline 6. 보안그룹 구성 . SSH 의 소스 항목을 "내 IP"로 변경 . 규칙추가 하여 유형을 "HTTP"로, 소스를 "내 IP"로 변경
7. 검토 및 시작. . 키페어를 선택할 수도 있으나, 이번에는 "키페어 없이 계속" 선택
CodePipeline으로 소스를 배포하는 예제. 과정이 간단한 것이 아니라 구조가 간단한 것임.
일반적으로는 commit - build - deploy의 구조를 가지는데 build를 빼고 commit - deploy 만 codepipeline으로 묶음.
사용하는 AWS제품은 CodeCommit, CodeDeploy, CodePipeline, S3 bucket, EC2
소스를 push하면 CodeDeploy Agent가 설치된 EC2에 배포한다. build라는 과정이 없기 때문에 간단과정이다.
이번 설명에서 AWS CodePipe라인은 다음 순서로 설정한다 1. CodeCommit 2. CodeDeploy 3. EC2 4. CodePipeline
CodeCommit Repository : simple-pipeline-repo Region : 서울 ap-northeast-2
먼저 CodeCommit에 Repository를 생성한다. . login
. codeCommit > repository > repository 생성 버튼 클릭
. repository 이름 넣고 "생성" 버튼 클릭. (simple-pipeline-repo)
*[참고]루트계정으로 작업하지 않는것을 권장하며 repository를 루트계정으로 생성하면 ssh로 작업을 할 수 없다 아래와 같이 https로만 연결 가능하므로 IAM 유저를 추가한 다음 작업하는 것을 추천.
. Repository가 생성되면 "연결 단계" 설정을 해야한다. HTTPS, SSH, HTTPS(GRC) 세 가지가 있으며 조금 복잡하지만 SSH 방식으로 진행한다. 아래 그림과 같이 연결단계는 MacOS, Windows, Linux 별 설정이 다르니 해당 OS에 맞는 설정을 한다. MacOS 를 클릭하면 설정방법이 나타난다.
. 1단계로 : 사전요구사항인데. 작업할 PC에 git이 깔려있어야 하고 IAM 유저가 CodeCommit를 쓰기위한 권한이 있어야하고 팀원초대하는데. 우선은 혼자 작업할 예정이므로 스킵. . 2단계 : SSH 퍼블릭 키 등록. Repository의 source를 git clone, push를 하기위해 키 등록을 해야한다. 적절한 권한이 없이 그냥 clone 하면 id/pass를 물어보고 권한이 없어서 안된다고 한다.
- 터미널에서 작업 #폴더 이동 cd ~/.ssh #Key 생성 ssh-keygen명령을 실행하고 keypair 파일명 입력 passphrase는 생략가능하므로 그냥 엔터만 쳐도 된다.(엔터 2번) ssh-keygen
Generating public/private rsa key pair. Enter file in which to save the key (/Users/user/.ssh/id_rsa): aws_seoul-codecommit-keypair Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in aws_seoul-codecommit-keypair Your public key has been saved in aws_seoul-codecommit-keypair.pub The key fingerprint is: xxxxx
** 다른 repository에서도 사용가능한지는 확인 안해봤으나 가능할 것으로 보고 이름을 좀 넓은 의미로 지음.
# ls 를 해 보면 1쌍의 key pair파일이 생성되었다. ( xxx.pub, xxx) ls
# xxx.pub파일의 내용 확인 cat ~/.ssh/aws-seoul-codecommit-keypair.pub 그러면 ssh-rsa ~~~ user-name@... 이 내용을 모두 복사한다. ex)
ssh-rsa AAAA - 중 간 생 략 -0K2xI71eoVRMe6fbp13WJl8mrtdYgxglfOCMnV9K+OFyeQj7/cuiw5uK0QadZywSBReMDhN4RkHKMBe6wW7KrLPRCoBOlFqnvXP4kFGOko4 - 중 간 생 략 -D8/6TjIgT2A+MgNuM= noman@MYPC.local
- AWS Console에서 작업 : SSH 퍼블릭 키 업로드 . IAM > 좌측메뉴 사용자 > 사용자 목록에서 사용자 선택 > 보안 자격 증명 Tab
. 아래로 scroll "AWS CodeCommit"에 대한 SSH 키 항목에 "SSH 퍼블릭 키 업로드" 버튼 클릭
. xxx.pub파일에 있는 내용을 붙여 넣는다.
. 생성하면 SSH KEY ID 가 생성된다. 사용하지 않을 때는 "비활성화"를 클릭하면 되고, 필요없을 때는 X 버튼을 누르면 된다.
. 3단계 : ssh 구성 편집 # config라는 파일을 생성하여 방금 생성한 ssh key id와 생성된 파일위치를 지정한다. vi config
Host git-codecommit.*.amazonaws.com User APKAQXV6Fxxxxx IdentityFile ~/.ssh/aws-seoul-codecommit-keypair
# config 파일에 권한 변경 : 작업 디렉토리는 반드시 ~/.ssh 여야한다. chmod 600 config
. 4단계 : Repository 복제 # 로컬로 clone # 작업할 directory로 이동 pwd cd ~/Documents/cicd # 접속Test : ssh key id 와 해당 region정보로 ssh APKAQXV6Fxxxxx@git-codecommit.ap-northeast-2.amazonaws.com 정상인 경우 아래와 같은 메세지가 나온다.
You have successfully authenticated over SSH. You can use Git to interact with AWS CodeCommit. Interactive shells are not supported.Connection to git-codecommit.ap-northeast-2.amazonaws.com closed by remote host. Connection to git-codecommit.ap-northeast-2.amazonaws.com closed.
# Clone : AWS console에서 해당 repository에 주소가 있으므로 그대로 복사. git clone ssh://git-codecommit.ap-northeast-2.amazonaws.com/v1/repos/simple-pipeline-repo
# yes를 입력하면 현재 소스는 없이 repository만 만들었으므로 빈 것 같다는 말이 나옴.
# ls -al 해 보면 simple-pipeline-repo 폴더가 생겼고 .git만 하나 있음. cd simple-pipeline-repo ls -al