fix: start.sh 빌드명 수정 #13
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: Deploy | |
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-and-deploy: | |
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: Check build result | |
run: ls -la build/libs | |
# 압축 파일 만들기 | |
- name: Make Zip File | |
run: zip -qq -r ./$GITHUB_SHA.zip . | |
shell: bash | |
- 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 | |
- name: Wait for deployment to finish | |
run: | | |
aws deploy wait deployment-successful --deployment-id $(aws deploy list-deployments --application-name $CODE_DEPLOY_APP_NAME --deployment-group-name $DEPLOYMENT_GROUP_NAME --query "deployments[0]" --output text) | |
- 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: Sleep for 90 seconds | |
run: sleep 90 | |
- name: Stop application | |
run: | | |
chmod +x /home/ubuntu/deploy/scripts/stop.sh | |
/home/ubuntu/deploy/scripts/stop.sh | |
env: | |
DEV_DB_URL: ${{ secrets.DEV_DB_URL }} | |
DEV_DB_USER: ${{ secrets.DEV_DB_USER }} | |
DEV_DB_PASSWORD: ${{ secrets.DEV_DB_PASSWORD }} | |
- name: Start application | |
run: | | |
chmod +x /home/ubuntu/deploy/scripts/start.sh | |
/home/ubuntu/deploy/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 }} |