Merge pull request #17 from CSID-DGU/feat/#11-cicd #3
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: CD | |
# 해당 workflow가 언제 실행될 것인지에 대한 트리거를 지정 | |
on: | |
push: | |
branches: [ develop ] # develop branch로 push 될 때 실행됩니다. | |
env: | |
S3_BUCKET_NAME: cecd1921-bucket | |
jobs: | |
build: | |
name: Code deployment | |
# 실행 환경 | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: checkout | |
uses: actions/checkout@v3 | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'corretto' | |
- name: Change to server directory # 'server' 디렉토리로 이동 | |
run: cd server | |
shell: bash | |
- name: make application.yml | |
run: | | |
## create application.yml | |
mkdir -p ./src/main/resources | |
cd ./src/main/resources | |
if [ ! -f ./application.yml ]; then | |
touch ./application.yml | |
echo "${{ secrets.CD_APPLICATION }}" >> ./application.yml | |
else | |
echo "application.yml 파일이 이미 존재합니다." | |
fi | |
echo "${{ secrets.CD_APPLICATION }}" >> ./application.yml | |
cat ./application.yml | |
shell: bash | |
- name: Grant execute permission for gradlew | |
run: | | |
cd server | |
chmod +x gradlew | |
- name: Build with Gradle # 실제 application build(-x 옵션을 통해 test는 제외) | |
run: | | |
cd server | |
./gradlew build -x test | |
- name: Make Directory | |
run: | | |
cd server | |
mkdir -p deploy | |
- name: Copy Jar | |
run: | | |
cd server | |
cp ./build/libs/*.jar ./deploy | |
- name: Copy appspec.yml | |
run: | | |
cd server | |
cp appspec.yml ./deploy | |
- name: Copy script | |
run: | | |
cd server | |
cp ./scripts/*.sh ./deploy | |
- name: Make zip file | |
run: | | |
cd server | |
zip -r ./cecd-1921.zip ./deploy | |
shell: bash | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_KEY }} | |
aws-region: ap-northeast-2 | |
- name: Upload to S3 | |
run: | | |
cd server | |
aws s3 cp --region ap-northeast-2 ./cecd-1921.zip s3://$S3_BUCKET_NAME/ | |
- name: Deploy | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_KEY }} | |
run: | | |
cd server | |
aws deploy create-deployment | |
--application-name cecd-1921-deploy | |
--deployment-group-name cecd-1921-deploy | |
--file-exists-behavior OVERWRITE | |
--s3-location bucket=$S3_BUCKET_NAME,bundleType=zip,key=cecd-1921.zip | |
--region ap-northeast-2 |