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 특정 브랜치에 내용이 머지되면 자동으로 배포가 된다.

반응형