Infra/[AWS]
[AWS] Github Actions로 NextJs,EC2,Docker CI/CD 구축
HiSmith
2024. 6. 6. 14:40
반응형
github action을 통해 브랜치에 푸시가 되면 자동으로 배포가 되도록 구축해보자
1. Git hub access-token 발급
Settings > Developer Setting을 통해, 아래 Classic Token을 생성하고, 잘 보관해 둔다.
2. 자동화 원하는 Repo의 secret key 연동
원하는 Repo > Setting > Secrets and variables> Actions 진입, 아까 만든 access token을 바탕으로
2번째 이미지처럼 키를 생성
3. Runner 설정
New self-hosted runner 클릭
해당 하위에 나오는 명령어를 ec2에 입력
* shaSum 오류 발생시 패키지 업데이트
sudo yum install perl-Digest-SHA -y
* ./run.sh를 하면 포그라운드 실행되어 아래 명령어로 입력
nohup ./run.sh &
4. Github Action 설정
진입 후 setup yourself 로 아래 workflow 스크립트를 넣어주면된다.
신경쓸건 아래 3가지 뿐이다.
Repository name 을 전부 lowercase로 해주는 것
실행시에 포트 번호
타겟 브랜치 정도이다.
ex.
name: CI/CD Docker
on:
push:
branches: [main] #브런츠 명 ex) [production, test]
env:
DOCKER_IMAGE: ghcr.io/${{ github.actor }}/healthlifefront
VERSION: ${{ github.sha }}
NAME: cicd_test
jobs:
build:
name: Build
runs-on: ubuntu-latest
steps:
- name: Check out source code
uses: actions/checkout@v2
- name: Set up docker buildx
id: buildx
uses: docker/setup-buildx-action@v1
- name: Cache docker layers
uses: actions/cache@v2
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-${{ env.VERSION }}
restore-keys: |
${{ runner.os }}-buildx-
- name: Login to ghcr
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GHCR_TOKEN }}
- name: Build and push
id: docker_build
uses: docker/build-push-action@v2
with:
builder: ${{ steps.buildx.outputs.name }}
push: true
tags: ${{ env.DOCKER_IMAGE }}:latest
deploy:
needs: build
name: Deploy
runs-on: [self-hosted, Linux, x64]
steps:
- name: Login to ghcr
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GHCR_TOKEN }}
- name: Docker run
run: |
docker stop ${{ env.NAME }} && docker rm ${{ env.NAME }} && docker rmi ${{ env.DOCKER_IMAGE }}:latest
docker run -d -p 80:3000 --name ${{ env.NAME }} --restart always ${{ env.DOCKER_IMAGE }}:latest
위와 같이 하면 git 특정 브랜치에 내용이 머지되면 자동으로 배포가 된다.
반응형