- 순찰/점검 기능 개선 (zone-detail 페이지 추가) - 출근/근태 시스템 개선 (연차 조회, 근무현황) - 작업분석 대분류 그룹화 및 마이그레이션 스크립트 - 모바일 네비게이션 UI 추가 - NAS 배포 도구 및 문서 추가 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
200 lines
3.5 KiB
Markdown
200 lines
3.5 KiB
Markdown
# API 서버 배포 가이드
|
|
|
|
## 자동 배포 (권장)
|
|
|
|
### 1. 배포 스크립트 실행
|
|
|
|
```bash
|
|
cd api.hyungi.net
|
|
|
|
# 처음 한 번만: 실행 권한 부여
|
|
chmod +x deploy.sh
|
|
|
|
# 배포 실행
|
|
./deploy.sh
|
|
```
|
|
|
|
배포 스크립트는 다음을 자동으로 처리합니다:
|
|
1. ✅ Git Pull
|
|
2. ✅ NPM Install (package.json 변경 시)
|
|
3. ✅ 데이터베이스 마이그레이션 (확인 후 실행)
|
|
4. ✅ PM2 서버 재시작
|
|
5. ✅ 상태 확인
|
|
|
|
---
|
|
|
|
## 수동 배포
|
|
|
|
### 1. Git Pull
|
|
```bash
|
|
cd api.hyungi.net
|
|
git pull
|
|
```
|
|
|
|
### 2. 의존성 설치 (package.json 변경 시)
|
|
```bash
|
|
npm install
|
|
```
|
|
|
|
### 3. 데이터베이스 마이그레이션
|
|
|
|
⚠️ **중요**: 마이그레이션 전 데이터베이스 백업을 권장합니다!
|
|
|
|
```bash
|
|
# 마이그레이션 실행
|
|
npm run db:migrate
|
|
|
|
# 마이그레이션 롤백 (문제 발생 시)
|
|
npm run db:rollback
|
|
```
|
|
|
|
### 4. PM2 서버 재시작
|
|
|
|
```bash
|
|
# 무중단 재시작 (권장)
|
|
pm2 reload ecosystem.config.js --env production
|
|
|
|
# 또는 일반 재시작
|
|
pm2 restart hyungi-api
|
|
|
|
# 서버 중지 후 시작
|
|
pm2 stop hyungi-api
|
|
pm2 start ecosystem.config.js --env production
|
|
```
|
|
|
|
---
|
|
|
|
## 배포 후 확인사항
|
|
|
|
### 1. 서버 상태 확인
|
|
```bash
|
|
# PM2 프로세스 목록
|
|
pm2 list
|
|
|
|
# 실시간 로그 확인
|
|
pm2 logs hyungi-api
|
|
|
|
# 에러 로그만 확인
|
|
pm2 logs hyungi-api --err
|
|
```
|
|
|
|
### 2. API 응답 확인
|
|
```bash
|
|
# Health Check
|
|
curl http://localhost:20005/health
|
|
|
|
# 또는
|
|
curl http://api.hyungi.net/health
|
|
```
|
|
|
|
### 3. 마이그레이션 상태 확인
|
|
```bash
|
|
# 현재 마이그레이션 버전 확인
|
|
npx knex migrate:currentVersion --knexfile knexfile.js
|
|
|
|
# 적용된 마이그레이션 목록
|
|
npx knex migrate:list --knexfile knexfile.js
|
|
```
|
|
|
|
---
|
|
|
|
## 문제 해결
|
|
|
|
### 마이그레이션 실패 시
|
|
|
|
1. **에러 로그 확인**
|
|
```bash
|
|
pm2 logs hyungi-api --err
|
|
```
|
|
|
|
2. **마이그레이션 롤백**
|
|
```bash
|
|
npm run db:rollback
|
|
```
|
|
|
|
3. **특정 마이그레이션만 실행**
|
|
```bash
|
|
npx knex migrate:up 20260119095549_add_worker_display_fields.js --knexfile knexfile.js
|
|
```
|
|
|
|
### 서버 시작 실패 시
|
|
|
|
1. **포트 충돌 확인**
|
|
```bash
|
|
lsof -i :20005
|
|
```
|
|
|
|
2. **PM2 프로세스 완전 삭제 후 재시작**
|
|
```bash
|
|
pm2 delete hyungi-api
|
|
pm2 start ecosystem.config.js --env production
|
|
```
|
|
|
|
3. **환경변수 확인**
|
|
```bash
|
|
cat .env
|
|
```
|
|
|
|
---
|
|
|
|
## 환경별 배포
|
|
|
|
### Development (개발)
|
|
```bash
|
|
NODE_ENV=development npm run db:migrate
|
|
pm2 reload ecosystem.config.js --env development
|
|
```
|
|
|
|
### Production (운영)
|
|
```bash
|
|
NODE_ENV=production npm run db:migrate
|
|
pm2 reload ecosystem.config.js --env production
|
|
```
|
|
|
|
---
|
|
|
|
## 데이터베이스 백업
|
|
|
|
### 백업 생성
|
|
```bash
|
|
# MySQL 백업
|
|
mysqldump -h DB_HOST -u DB_USER -p DB_NAME > backup_$(date +%Y%m%d_%H%M%S).sql
|
|
```
|
|
|
|
### 백업 복구
|
|
```bash
|
|
mysql -h DB_HOST -u DB_USER -p DB_NAME < backup_20260119_120000.sql
|
|
```
|
|
|
|
---
|
|
|
|
## CI/CD 자동화 (향후 개선안)
|
|
|
|
GitHub Actions 또는 GitLab CI/CD를 사용한 자동 배포:
|
|
|
|
```yaml
|
|
# .github/workflows/deploy.yml 예시
|
|
name: Deploy to Production
|
|
|
|
on:
|
|
push:
|
|
branches: [ master ]
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: SSH and Deploy
|
|
run: |
|
|
ssh user@server 'cd /path/to/api.hyungi.net && ./deploy.sh'
|
|
```
|
|
|
|
---
|
|
|
|
## 참고사항
|
|
|
|
- **마이그레이션은 한 방향으로만 진행** (forward-only)
|
|
- **rollback은 개발 환경에서만 사용 권장**
|
|
- **운영 환경에서는 반드시 백업 후 마이그레이션**
|
|
- **PM2 reload는 무중단 재시작** (downtime 없음)
|