Skip to content

오류 수정

오류 수정 #60

name: campus-table-cicd.yml
on:
push:
branches:
- main
- test
env:
PROJECT_NAME: campus-table
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: 코드 체크아웃
uses: actions/checkout@v4
- name: JDK 설정
uses: actions/setup-java@v4
with:
java-version: '21'
distribution: 'temurin'
cache: 'gradle'
- name: Gradle Wrapper 실행권한 부여
run: chmod +x gradlew
# application-prod.yml 파일을 빌드 전에 생성
- name: Create application-prod.yml from secret
run: |
echo "${{ secrets.APPLICATION_PROD_YML }}" > src/main/resources/application-prod.yml
# 브랜치 별 active profile 설정
- name: Decide active profile
id: profile
run: |
if [ "${GITHUB_REF_NAME}" = "deploy" ]; then
echo "PROFILE=deploy" >> $GITHUB_OUTPUT
else
echo "PROFILE=prod" >> $GITHUB_OUTPUT
fi
- name: Build with Gradle
run: ./gradlew clean build -x test -Dspring.profiles.active=${{ steps.profile.outputs.PROFILE }}
- name: Docker 빌드환경 설정
uses: docker/setup-buildx-action@v3
- name: DockerHub 로그인
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Cache Docker layers
uses: actions/cache@v4
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-${{ hashFiles('Dockerfile') }}
restore-keys: |
${{ runner.os }}-buildx-
- name: Docker 이미지 빌드 및 푸시
uses: docker/build-push-action@v5
with:
context: .
file: ./Dockerfile
push: true
tags: ${{ secrets.DOCKERHUB_USERNAME }}/${{ env.PROJECT_NAME }}-back:${{ github.ref_name }}
cache-from: type=registry,ref=${{ secrets.DOCKERHUB_USERNAME }}/${{ env.PROJECT_NAME }}:cache
cache-to: type=inline
deploy:
needs: build
runs-on: ubuntu-latest
steps:
- name: Deploy
uses: appleboy/ssh-action@v1.0.3
with:
host: ${{ secrets.SERVER_HOST }}
username: ${{ secrets.SERVER_USER }}
password: ${{ secrets.SERVER_PASSWORD }}
port: ${{ secrets.SERVER_PORT }}
script: |
set -e
echo "환경변수 설정.."
export PATH=$PATH:/usr/local/bin
export PW=${{ secrets.SERVER_PASSWORD }}
BRANCH=${{ github.ref_name }}
PORT=8080
CONTAINER_NAME=${{ env.PROJECT_NAME }}-back
PROFILE="prod"
IMAGE=${{ secrets.DOCKERHUB_USERNAME }}/${{ env.PROJECT_NAME }}-back:${BRANCH}
if [ "$BRANCH" == "main" ]; then
PORT=8087
elif [ "$BRANCH" == "test" ]; then
CONTAINER_NAME=${{ env.PROJECT_NAME }}-back-test
PORT=8088
fi
echo "브랜치: $BRANCH"
echo "컨테이너 이름: $CONTAINER_NAME"
echo "포트: $PORT"
echo "활성 프로필: $PROFILE"
echo "도커 이미지 풀 : $IMAGE"
echo $PW | sudo -S docker pull $IMAGE
echo "컨테이너 $CONTAINER_NAME 존재 여부 확인 중..."
if sudo docker ps -a --format '{{.Names}}' | grep -Eq "^${CONTAINER_NAME}\$"; then
echo "컨테이너 $CONTAINER_NAME 이(가) 존재합니다. 중지 및 삭제 중..."
echo $PW | sudo -S docker rm -f $CONTAINER_NAME
echo "컨테이너 $CONTAINER_NAME 이(가) 삭제되었습니다."
else
echo "존재하는 컨테이너 $CONTAINER_NAME 이(가) 없습니다."
fi
echo "새로운 컨테이너 $CONTAINER_NAME 실행 중..."
echo $PW | sudo -S docker run -d -p ${PORT}:8080 --name $CONTAINER_NAME \
-e TZ=Asia/Seoul \
-e "SPRING_PROFILES_ACTIVE=${PROFILE}" \
-v /etc/localtime:/etc/localtime:ro \
-v /docker/volume/backend/${BRANCH}:/app \
${IMAGE}
# <none> 태그로 남은 이미지 정리
echo "불필요한 dangling(<none>) 이미지 정리..."
echo $PW | sudo -S docker image prune -af
echo "배포가 성공적으로 완료되었습니다."