Skip to content

cicd: Dockerfile 경로 수정 테스트 #88

cicd: Dockerfile 경로 수정 테스트

cicd: Dockerfile 경로 수정 테스트 #88

Workflow file for this run

name: Deploy to Production
on:
push:
branches:
- develop
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout source code
uses: actions/checkout@master
with:
token: ${{ secrets.ACTION_TOKEN }}
submodules: true
- name: Update submodules
run: git submodule update --remote
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'zulu'
- name: Gradle Caching
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: Build with Gradle
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: ./gradlew :core:core-api:build
# 배포에 필요한 여러 설정 파일과 프로젝트 빌드 파일을 zip 파일로 모아준다.
- name: Make zip file
run: |
mkdir deploy
cp ./docker/docker-compose.yml ./deploy/
cp ./appspec.yml ./deploy/
cp ./scripts/deploy.sh ./deploy/
cp ./Dockerfile ./deploy/
cp ./core/core-api/build/libs/core-api-0.0.1-SNAPSHOT.jar ./deploy/
zip -r -qq -j ./spring-build.zip ./deploy
- 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
- name: Upload to S3
run: |
aws s3 cp \
--region ap-northeast-2 \
./spring-build.zip s3://melly-s3
# 추가
- name: Code Deploy
run: aws deploy create-deployment --application-name melly
--deployment-config-name CodeDeployDefault.HalfAtATime
--deployment-group-name melly-group
--s3-location bucket=melly-s3,bundleType=zip,key=spring-build.zip