Skip to content

chore: docker-compose 수정 #11

chore: docker-compose 수정

chore: docker-compose 수정 #11

Workflow file for this run

name: Deploy Application
on:
push:
branches: [main]
paths:
- 'apps/**'
- 'docker-compose.yml'
- 'nginx/**'
- '.github/workflows/deploy.yml'
jobs:
test:
runs-on: ubuntu-latest
name: Run Tests
environment: ${{'prod'}}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: 'node'
- name: Install pnpm
run: npm install -g pnpm
- name: Install dependencies
run: pnpm install --no-frozen-lockfile
- name: Test backend
working-directory: apps/backend
run: pnpm test
- name: Test frontend
working-directory: apps/frontend
run: pnpm test
build-and-push:
needs: test
runs-on: ubuntu-latest
name: Build and Push Docker Images
environment: ${{'prod'}}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Install Docker Compose
run: |
sudo curl -L "https://github.com/docker/compose/releases/download/v2.24.1/docker-compose-linux-x86_64" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build and push with Docker Compose
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_TAG: ${{ secrets.DOCKER_TAG }}
NODE_ENV: ${{ secrets.NODE_ENV }}
SESSION_SECRET: ${{ secrets.SESSION_SECRET }}
DB_PORT: ${{ secrets.DB_PORT }}
DB_USERNAME: ${{ secrets.DB_USERNAME }}
DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
DB_DATABASE: ${{ secrets.DB_DATABASE }}
DB_SYNCHRONIZE: ${{ secrets.DB_SYNCHRONIZE }}
DB_ROOT_PASSWORD: ${{ secrets.DB_ROOT_PASSWORD }}
run: |
docker-compose build
docker-compose push
deploy:
needs: build-and-push
runs-on: ubuntu-latest
name: Deploy to Server
environment: ${{'prod'}}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up SSH Key
run: |
mkdir -p ~/.ssh
echo "${{ secrets.PUBLIC_SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
chmod 600 ~/.ssh/id_rsa
ssh-keyscan -t rsa ${{ secrets.PUBLIC_SERVER_IP }} >> ~/.ssh/known_hosts
- name: Deploy to server
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_TAG: ${{ secrets.DOCKER_TAG }}
NODE_ENV: ${{ secrets.NODE_ENV }}
SESSION_SECRET: ${{ secrets.SESSION_SECRET }}
DB_PORT: ${{ secrets.DB_PORT }}
DB_USERNAME: ${{ secrets.DB_USERNAME }}
DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
DB_DATABASE: ${{ secrets.DB_DATABASE }}
DB_SYNCHRONIZE: ${{ secrets.DB_SYNCHRONIZE }}
MYSQL_ROOT_PASSWORD: ${{ secrets.MYSQL_ROOT_PASSWORD }}
run: |
# 배포 디렉토리 생성
ssh -i ~/.ssh/id_rsa ${{ secrets.DEPLOY_USER }}@${{ secrets.PUBLIC_SERVER_IP }} "mkdir -p ~/booquiz"
# 필요한 파일들을 서버로 복사
scp -i ~/.ssh/id_rsa docker-compose.yml ${{ secrets.DEPLOY_USER }}@${{ secrets.PUBLIC_SERVER_IP }}:~/booquiz/
scp -i ~/.ssh/id_rsa -r nginx ${{ secrets.DEPLOY_USER }}@${{ secrets.PUBLIC_SERVER_IP }}:~/booquiz/
# 환경 변수 파일 생성 및 서비스 배포
ssh -i ~/.ssh/id_rsa ${{ secrets.DEPLOY_USER }}@${{ secrets.PUBLIC_SERVER_IP }} "
cd ~/booquiz
cat > .env << EOL
DOCKER_USERNAME=$DOCKER_USERNAME
DOCKER_TAG=$DOCKER_TAG
NODE_ENV=$NODE_ENV
SESSION_SECRET=$SESSION_SECRET
DB_PORT=$DB_PORT
DB_USERNAME=$DB_USERNAME
DB_PASSWORD=$DB_PASSWORD
DB_DATABASE=$DB_DATABASE
DB_SYNCHRONIZE=$DB_SYNCHRONIZE
MYSQL_ROOT_PASSWORD=$MYSQL_ROOT_PASSWORD
EOL
sudo docker network create booquiz || true
sudo docker-compose pull
sudo docker-compose up -d
sudo docker image prune -f
"