Skip to content

Running

Running #105

name: CICD
run-name: Running
on:
push:
branches:
- release
pull_request:
branches:
- release
env:
AWS_REGION: ap-northeast-2
ECR_REPOSITORY: chzz-rep
ECS_SERVICE: chzz-market
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: check out
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'corretto'
- name: AWS credential 설정
uses: aws-actions/configure-aws-credentials@v1
with:
aws-region: ${{ env.AWS_REGION }}
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
- name: ECR 로그인
id: login-ecr
uses: aws-actions/amazon-ecr-login@v1
- name: S3에서 설정파일 복사
run: |
aws s3 cp s3://chzzmarket-production-storage/chzz-production-properties/application-prod.yml \
./src/main/resources/application-prod.yml
- name: gradle 실행 권한 부여
run: chmod +x ./gradlew
- name: gradle 빌드
run: ./gradlew build -x test -i
- name: Docker 이미지 빌드 및 ECR 배포
id: build-image
env:
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }}
IMAGE_TAG: ${{ github.sha }}
run: |
docker build -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG .
docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG
echo "::set-output name=image::$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG"
- name: 기존 `compose.yaml` 파일 삭제
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.EC2_IP }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
rm -f /home/ec2-user/compose.yaml
- name: EC2로 `docker-compose.yml` 파일 복사
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_IP }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
source: './compose.yaml'
target: '/home/ec2-user'
- name: EC2로 `nginx.conf` 파일 복사
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_IP }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
source: './nginx.conf'
target: '/home/ec2-user'
- name: EC2에서 .env 파일 생성
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.EC2_IP }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
touch /home/ec2-user/.env
echo ECR_IMAGE=${{ steps.build-image.outputs.image }} >> /home/ec2-user/.env
- name: EC2에서 Docker Compose를 통한 애플리케이션 실행
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.EC2_IP }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
export AWS_REGION=${{ env.AWS_REGION }}
export ECR_URI=${{ secrets.ECR_URI }}
# ECR 레지스트리에 로그인
aws ecr get-login-password --region $AWS_REGION | sudo docker login --username AWS --password-stdin $ECR_URI/chzz-rep
# 기존 컨테이너 정지 및 삭제
sudo docker compose down
# 최신 이미지를 가져와서 환경 변수로 전달
sudo docker compose --env-file /home/ec2-user/.env pull
# Docker Compose로 애플리케이션 실행
sudo docker compose --env-file /home/ec2-user/.env up -d