Merge branch 'main' of https://github.com/googoo9918/YourssuAssignment #7
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
# Workflow의 이름을 지정합니다. | |
name: BackEnd - CI/CD | |
on: | |
push: | |
# main branch에 push(merge)될 경우 실행됩니다. | |
branches: ["main"] | |
permissions: | |
contents: read | |
jobs: | |
build: | |
# build를 진행할 운영체제를 선택합니다. | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
# JDK를 11 버전으로 셋팅합니다. | |
- name: Set up JDK 11 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '11' | |
distribution: 'temurin' | |
# Gradle을 캐싱해둡니다 -> 빌드 속도가 증가하는 효과가 있습니다. | |
- name: Gradle 캐싱 | |
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: Make application.yml | |
run: | | |
# src/main 으로 경로를 이동합니다. | |
cd ./src/main | |
# src/main 경로에 resources 폴더를 만들어줍니다. | |
cd ./resources | |
# 필요한 yml 파일들을 만들어줍니다. | |
touch ./application.yml | |
# 등록해둔 Github Secrets의 내용을 이용해서 yml 파일의 내용을 써줍니다. | |
echo "$APPLICATION" > ./application.yml | |
env: | |
APPLICATION: ${{ secrets.APPLICATION }} | |
shell: bash | |
- name: Gradle 권한 부여 | |
run: chmod +x gradlew | |
- name: Gradle로 빌드 실행 | |
run: ./gradlew bootjar | |
# 배포에 필요한 여러 설정 파일과 프로젝트 빌드파일을 zip 파일로 모아줍니다. | |
- name: zip file 생성 | |
run: | | |
mkdir deploy | |
cp ./docker/docker-compose.blue.yml ./deploy/ | |
cp ./docker/docker-compose.green.yml ./deploy/ | |
cp ./appspec.yml ./deploy/ | |
cp ./docker/Dockerfile ./deploy/ | |
cp ./scripts/*.sh ./deploy/ | |
cp ./build/libs/*.jar ./deploy/ | |
zip -r -qq -j ./spring-build.zip ./deploy | |
# AWS에 연결해줍니다. | |
- name: AWS 연결 | |
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: ${{ secrets.AWS_REGION }} | |
# S3에 프로젝트를 업로드 합니다. | |
- name: S3에 프로젝트 업로드 | |
run: | | |
aws s3 cp \ | |
--region ap-northeast-2 \ | |
./spring-build.zip s3://yourssu-incubating-bucket | |
# CodeDelploy에 배포를 요청합니다. | |
- name: Code Deploy 배포 요청 | |
run: aws deploy create-deployment --application-name yourssu-app | |
--deployment-config-name CodeDeployDefault.OneAtATime | |
--deployment-group-name yourssu-app | |
--s3-location bucket=yourssu-incubating-bucket,bundleType=zip,key=spring-build.zip | |
# 이 구문을 추가해야 빌드 성공 실패와 상관없이 동작합니다. | |
if: always() |