Merge pull request #328 from EAT-SSU/develop #130
This file contains hidden or 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: EAT-SSU Server ๊ฐ๋ฐ & ์ด์ ์๋ฒ ๋ฐฐํฌ ํ์ดํ๋ผ์ธ | |
| on: | |
| push: | |
| branches: [ "main", "develop", "hotfix/deploy-prod-fail", "hotfix/deploy-dev-fail" ] | |
| permissions: | |
| contents: read | |
| jobs: | |
| CI-CD: | |
| name: CI/CD | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v3 | |
| - name: JDK 17 ์ค์น | |
| uses: actions/setup-java@v3 | |
| with: | |
| java-version: '17' | |
| distribution: 'temurin' | |
| - 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: dev ํ๋กํ ์ค์ | |
| if: github.ref_name == 'develop' || github.ref_name == 'hotfix/deploy-dev-fail' | |
| run: | | |
| echo "spring: | |
| profiles: | |
| include: dev" > ./src/main/resources/application.yml | |
| shell: bash | |
| - name: prod ํ๋กํ ์ค์ | |
| if: github.ref_name == 'main' || github.ref_name == 'hotfix/deploy-prod-fail' | |
| run: | | |
| echo "spring: | |
| profiles: | |
| include: prod" > ./src/main/resources/application.yml | |
| shell: bash | |
| - name: gradlew ์คํ ๊ถํ ๋ถ์ฌ | |
| run: chmod +x gradlew | |
| - name: Gradle๋ก ๋น๋ | |
| run: ./gradlew clean build -x test | |
| - name: Docker Hub ๋ก๊ทธ์ธ | |
| uses: docker/login-action@v2 | |
| with: | |
| username: ${{ secrets.DOCKER_USERNAME }} | |
| password: ${{ secrets.DOCKER_PASSWORD }} | |
| - name: prod ์ฉ Docker ๋น๋ ๋ฐ ํธ์ | |
| if: github.ref_name == 'main' || github.ref_name == 'hotfix/deploy-prod-fail' | |
| run: | | |
| docker build -f Dockerfile -t ${{ secrets.DOCKER_REPO }}/eatssu-prod . | |
| docker push ${{ secrets.DOCKER_REPO }}/eatssu-prod | |
| - name: dev ์๋ฒ ์ฉ Docker ๋น๋ ๋ฐ ํธ์ | |
| if: github.ref_name == 'develop' || github.ref_name == 'hotfix/deploy-dev-fail' | |
| run: | | |
| docker build -f Dockerfile -t ${{ secrets.DOCKER_REPO }}/eatssu-dev . | |
| docker push ${{ secrets.DOCKER_REPO }}/eatssu-dev | |
| - name: prod์ ๋ฐฐํฌ | |
| uses: appleboy/ssh-action@master | |
| id: deploy-prod | |
| if: github.ref_name == 'main' || github.ref_name == 'hotfix/deploy-prod-fail' | |
| with: | |
| host: ${{ secrets.HOST_PROD }} | |
| username: ${{ secrets.USERNAME }} | |
| key: ${{ secrets.PROD_PRIVATE_KEY }} | |
| port: 22 | |
| script: | | |
| sudo docker ps | |
| sudo docker rm -f $(docker ps -qa) | |
| sudo docker pull ${{ secrets.DOCKER_REPO }}/eatssu-prod | |
| sudo docker run -d -p 9000:9000 \ | |
| --log-driver=awslogs \ | |
| --log-opt awslogs-region=ap-northeast-2 \ | |
| --log-opt awslogs-group=prod-ec2-group \ | |
| --log-opt awslogs-stream=prod-$(date +%Y%m%d-%H%M%S) \ | |
| -e EATSSU_DB_URL_PROD="${{ secrets.EATSSU_DB_URL_PROD }}" \ | |
| -e EATSSU_DB_USERNAME="${{ secrets.EATSSU_DB_USERNAME }}" \ | |
| -e EATSSU_DB_PASSWORD="${{ secrets.EATSSU_DB_PASSWORD }}" \ | |
| -e EATSSU_JWT_SECRET_PROD="${{ secrets.EATSSU_JWT_SECRET_PROD }}" \ | |
| -e EATSSU_AWS_ACCESS_KEY_PROD="${{ secrets.EATSSU_AWS_ACCESS_KEY_PROD }}" \ | |
| -e EATSSU_AWS_SECRET_KEY_PROD="${{ secrets.EATSSU_AWS_SECRET_KEY_PROD }}" \ | |
| -e EATSSU_SLACK_TOKEN="${{ secrets.EATSSU_SLACK_TOKEN }}" \ | |
| -e EATSSU_PROD_DOMAIN="${{ secrets.EATSSU_PROD_DOMAIN }}" \ | |
| ${{ secrets.DOCKER_REPO }}/eatssu-prod | |
| sudo docker image prune -f | |
| - name: dev ์๋ฒ์ ๋ฐฐํฌ | |
| uses: appleboy/ssh-action@master | |
| id: deploy-dev | |
| if: github.ref_name == 'develop' || github.ref_name == 'hotfix/deploy-dev-fail' | |
| with: | |
| host: ${{ secrets.HOST_DEV }} | |
| username: ${{ secrets.USERNAME }} | |
| port: 22 | |
| key: ${{ secrets.DEV_PRIVATE_KEY }} | |
| script: | | |
| sudo docker ps | |
| sudo docker rm -f $(docker ps -qa) | |
| sudo docker pull ${{ secrets.DOCKER_REPO }}/eatssu-dev | |
| sudo docker run -d -p 9000:9000 \ | |
| --log-driver=awslogs \ | |
| --log-opt awslogs-region=ap-northeast-2 \ | |
| --log-opt awslogs-group=dev-ec2-group \ | |
| --log-opt awslogs-stream=dev-$(date +%Y%m%d-%H%M%S) \ | |
| -e EATSSU_DB_URL_DEV="${{ secrets.EATSSU_DB_URL_DEV }}" \ | |
| -e EATSSU_DB_USERNAME="${{ secrets.EATSSU_DB_USERNAME }}" \ | |
| -e EATSSU_DB_PASSWORD="${{ secrets.EATSSU_DB_PASSWORD }}" \ | |
| -e EATSSU_JWT_SECRET_DEV="${{ secrets.EATSSU_JWT_SECRET_DEV }}" \ | |
| -e EATSSU_AWS_ACCESS_KEY_DEV="${{ secrets.EATSSU_AWS_ACCESS_KEY_DEV }}" \ | |
| -e EATSSU_AWS_SECRET_KEY_DEV="${{ secrets.EATSSU_AWS_SECRET_KEY_DEV }}" \ | |
| -e EATSSU_SLACK_TOKEN="${{ secrets.EATSSU_SLACK_TOKEN }}" \ | |
| -e EATSSU_DEV_DOMAIN="${{ secrets.EATSSU_DEV_DOMAIN }}" \ | |
| ${{ secrets.DOCKER_REPO }}/eatssu-dev | |
| sudo docker image prune -f |