Skip to content

Merge branch 'main' of https://github.com/prgrms-be-devcourse/NBB1_2_… #116

Merge branch 'main' of https://github.com/prgrms-be-devcourse/NBB1_2_…

Merge branch 'main' of https://github.com/prgrms-be-devcourse/NBB1_2_… #116

Workflow file for this run

name: Java & React CI/CD
on:
push:
branches: [ "main", "release" ]
pull_request:
branches: [ "main", "release" ]
jobs:
build:
if: github.repository == 'prgrms-be-devcourse/NBB1_2_3_Team10'
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
# application-prod.properties 암호화
- name: add secrets into properties
run: |
echo "${{ secrets.APPLICATION_PROD }}" | base64 --decode > ./src/main/resources/application-prod.properties
# 환경 설정
- name: Setup Gradle
uses: gradle/gradle-build-action
# 실행 권한 부여
- name: Grant execute permission for Gradlew
run: chmod +x gradlew
# 프로젝트 빌드 (clean bootJar로 빌드만 수행)
- name: Build with Gradle Wrapper
run: ./gradlew build
# Docker Hub 로그인
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
# Docker 이미지 빌드 및 푸시
- name: Build and push Docker image
run: |
docker build -t ${{ secrets.DOCKER_USERNAME }}/bitta-kotlin:latest .
docker push ${{ secrets.DOCKER_USERNAME }}/bitta-kotlin:latest
deploy:
if: github.repository == 'prgrms-be-devcourse/NBB1_2_3_Team10' && github.ref == 'refs/heads/release'
needs: build
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
# EC2 서버 배포
- name: Deploy to EC2
uses: appleboy/[email protected]
with:

Check failure on line 72 in .github/workflows/CICD.yml

View workflow run for this annotation

GitHub Actions / .github/workflows/CICD.yml

Invalid workflow file

You have an error in your yaml syntax on line 72
host: ${{ secrets.EC2_HOST }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
echo "${{ secrets.DOCKER_PASSWORD }}" | docker login -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin
docker pull ${{ secrets.DOCKER_USERNAME }}/bitta-kotlin:latest
docker stop my-container || true
docker rm my-container || true
docker run -d --name my-container -p 8080:80 ${{ secrets.DOCKER_USERNAME }}/bitta-kotlin:latest
# 현재 활성화된 blue/green 컨테이너 확인
CURRENT_CONTAINER=$(docker ps --filter "name=backend-blue" -q)
if [ -n "$CURRENT_CONTAINER" ]; then
TARGET_CONTAINER="backend-green"
else
TARGET_CONTAINER="backend-blue"
fi
# 새 컨테이너 시작
docker stop $TARGET_CONTAINER || true
docker rm $TARGET_CONTAINER || true
docker run -d --name $TARGET_CONTAINER -p 8080:80 \
-e NODE_ENV=production \
${{ secrets.DOCKER_USERNAME }}/bitta-kotlin:latest
# Nginx 리로드하여 트래픽 전환
sudo systemctl reload nginx