refactor: 인증 경로 추가 (#noisssue) #80
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: 'work' | |
# | |
#on: | |
# push: | |
# branches: | |
# - 'main' | |
# | |
#jobs: | |
# update: | |
# name: 프로젝트 버전 업데이트 | |
# runs-on: ubuntu-latest | |
# steps: | |
# - name: Checkout code | |
# uses: actions/checkout@v2 | |
# | |
# - name: Set up JDK 17 | |
# uses: actions/setup-java@v2 | |
# with: | |
# java-version: '17' | |
# distribution: 'adopt' | |
# | |
# build: | |
# name: 이미지 빌드 및 도커허브 푸시 | |
# runs-on: ubuntu-latest | |
# needs: update | |
# steps: | |
# - uses: actions/checkout@v3 | |
# with: | |
# ref: refs/heads/main | |
# | |
# - name: application-prod.yml 생성 | |
# env: | |
# ACTIONS_STEP_DEBUG: true | |
# APPLICATION_PROD: ${{ secrets.APPLICATION_PROD_YML }} | |
# run: echo "$APPLICATION_PROD" > src/main/resources/application-prod.yml | |
# | |
# | |
# - name: jdk 17 설치 | |
# uses: actions/setup-java@v3 | |
# with: | |
# java-version: '17' | |
# distribution: 'temurin' | |
# cache: 'gradle' | |
# | |
# - name: gradlew 실행 권한 부여 | |
# run: chmod +x gradlew | |
# | |
# - name: gradle 빌드 | |
# run: ./gradlew build --no-daemon -i | |
# | |
# - name: build 폴더를 캐시에 저장 | |
# uses: actions/upload-artifact@v3 | |
# with: | |
# name: build-artifact | |
# path: build | |
# retention-days: 1 | |
# - name: 도커 이미지 빌드 및 푸시 | |
# run: | | |
# docker login -u ${{ secrets.DOCKER_HUB_USERNAME }} -p ${{ secrets.DOCKER_HUB_PASSWORD }} | |
# docker build -t ${{ secrets.DOCKER_REPO }}/gadduck . | |
# docker push ${{ secrets.DOCKER_REPO }}/gadduck | |
# deploy: | |
# name: 원격 서버에 배포 | |
# runs-on: ubuntu-latest | |
# needs: build | |
# steps: | |
# - name: 원격 서버에 배포하기 | |
# uses: appleboy/ssh-action@master | |
# with: | |
# host: ${{ secrets.SSH_HOST }} | |
# username: ${{ secrets.SSH_USER }} | |
# key: ${{ secrets.SSH_KEY }} | |
# port: 22 | |
# script: | | |
# sudo docker login -u ${{ secrets.DOCKER_HUB_USERNAME }} -p ${{ secrets.DOCKER_HUB_PASSWORD }} | |
# sudo docker stop gadduck_app || true | |
# sudo docker rm gadduck_app || true | |
# sudo docker pull ${{ secrets.DOCKER_REPO }}/gadduck | |
# sudo docker run --name=gadduck_app --restart unless-stopped \ | |
# -p 8080:8080 -e TZ=Asia/Seoul -d ${{ secrets.DOCKER_REPO }}/gadduck | |
# sudo docker image prune -f | |
name: ✨ gadduck backend PROD CD ✨ | |
on: | |
push: | |
branches: | |
- 'main' | |
jobs: | |
backend-docker-build-and-push: | |
runs-on: ubuntu-latest | |
steps: | |
- name: ✨ Checkout repository | |
uses: actions/checkout@v3 | |
with: | |
ref: refs/heads/main | |
- name: application-prod.yml 생성 | |
env: | |
ACTIONS_STEP_DEBUG: true | |
APPLICATION_PROD: ${{ secrets.APPLICATION_PROD_YML }} | |
run: echo "$APPLICATION_PROD" > src/main/resources/application-prod.yml | |
- name: ✨ JDK 17 설정 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'temurin' | |
- 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: ✨ Gradlew 권한 설정 | |
run: chmod +x ./gradlew | |
- name: ✨ Jar 파일 빌드 | |
run: ./gradlew bootJar | |
- name: ✨ DockerHub에 로그인 | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_HUB_USERNAME }} | |
password: ${{ secrets.DOCKER_HUB_PASSWORD }} | |
- name: ✨ Docker Image 빌드 후 DockerHub에 Push | |
uses: docker/build-push-action@v4 | |
with: | |
context: . | |
file: ./Dockerfile | |
push: true | |
platforms: linux/amd64 | |
tags: ${{ secrets.DOCKER_REPO }}/gadduck:latest | |
backend-docker-pull-and-run: | |
runs-on: [ self-hosted, prod ] | |
if: ${{ needs.backend-docker-build-and-push.result == 'success' }} | |
needs: [ backend-docker-build-and-push ] | |
steps: | |
- name: ✨ 배포 스크립트 실행 | |
run: | | |
sh /home/ubuntu/deploy.sh |