CICD 설정 및 rds 연동 #1
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test | |
on: | |
pull_request: | |
branches: [ "main" ] | |
push: | |
branches: [ "main" ] | |
env: | |
# 버킷에 저장할 폴더 이름 | |
PROJECT_NAME: ledger | |
# S3 버킷 이름 | |
BUCKET_NAME: newdealledger | |
# CodeDeploy의 애플리케이션 이름 | |
CODE_DEPLOY_APP_NAME: newdeal-ledger | |
# CodeDeploy의 배포그룹 이름 | |
DEPLOYMENT_GROUP_NAME: newdeal-ledger-deployment-group | |
jobs: | |
build: | |
# 실행 환경 설정 | |
runs-on: ubuntu-latest | |
# 차례대로 실행 | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v1 | |
with: | |
java-version: 17 | |
- name: Grant execute permission for gradlew | |
run: chmod +x gradlew | |
# Gradle build (Test 제외) | |
- name: Build with Gradle | |
run: ./gradlew clean build -x test | |
# 압축 파일 만들기 | |
- name: Make Zip File | |
run: zip -qq -r ./$GITHUB_SHA.zip . | |
shell: bash | |
# AWS 인증 | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: ap-northeast-2 | |
# S3 버킷으로 파일을 업로드 | |
- name: Upload to S3 | |
run: aws s3 cp --region ap-northeast-2 ./$GITHUB_SHA.zip s3://$BUCKET_NAME/$PROJECT_NAME/$GITHUB_SHA.zip | |
# S3 버킷에 업로드 된 파일을 대상으로 CodeDeploy에서 배포 요청 | |
- name: Code Deploy | |
run: aws deploy create-deployment --application-name $CODE_DEPLOY_APP_NAME --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name $DEPLOYMENT_GROUP_NAME --s3-location bucket=$BUCKET_NAME,bundleType=zip,key=$PROJECT_NAME/$GITHUB_SHA.zip | |
deploy: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v2 | |
- name: Set up environment variables | |
run: | | |
echo "DEV_DB_URL=${{ secrets.DEV_DB_URL }}" >> $GITHUB_ENV | |
echo "DEV_DB_USER=${{ secrets.DEV_DB_USER }}" >> $GITHUB_ENV | |
echo "DEV_DB_PASSWORD=${{ secrets.DEV_DB_PASSWORD }}" >> $GITHUB_ENV | |
- name: Deploy application | |
run: | | |
chmod +x ./scripts/start.sh | |
./scripts/start.sh | |
env: | |
DEV_DB_URL: ${{ secrets.DEV_DB_URL }} | |
DEV_DB_USER: ${{ secrets.DEV_DB_USER }} | |
DEV_DB_PASSWORD: ${{ secrets.DEV_DB_PASSWORD }} |