Files
jaryo/synology-setup.md

249 lines
5.6 KiB
Markdown

# 시놀로지 NAS에서 Jaryo File Manager 서비스 실행 가이드
## 1. 사전 준비사항
### 1.1 DSM 패키지 설치
1. **DSM 제어판****패키지 센터** 접속
2. 다음 패키지들을 설치:
- **Node.js** (최신 LTS 버전 권장)
- **Git Server** (선택사항, 소스코드 관리용)
- **Web Station** (선택사항, 웹 서버 프록시용)
### 1.2 SSH 활성화
1. **DSM 제어판****터미널 및 SNMP****SSH 서비스 활성화**
2. 포트 번호 확인 (기본: 22)
## 2. 프로젝트 배포
### 2.1 방법 1: 직접 파일 업로드 (간단한 방법)
1. **File Station**에서 `/volume1/web/` 폴더 생성
2. 프로젝트 파일들을 `jaryo` 폴더에 업로드
3. SSH로 접속하여 설정
### 2.2 방법 2: Git을 통한 배포 (권장)
```bash
# NAS에 SSH 접속
ssh admin@your-nas-ip
# 프로젝트 디렉토리 생성
mkdir -p /volume1/web/jaryo
cd /volume1/web/jaryo
# Git 저장소 클론 (로컬에서 push한 경우)
git clone [your-repository-url] .
# 또는 로컬에서 직접 파일 복사
# scp -r ./jaryo/* admin@your-nas-ip:/volume1/web/jaryo/
```
## 3. 서비스 설정 및 실행
### 3.1 스크립트 권한 설정
```bash
# SSH로 NAS 접속
ssh admin@your-nas-ip
# 프로젝트 디렉토리로 이동
cd /volume1/web/jaryo
# 스크립트 실행 권한 부여
chmod +x start-service.sh
chmod +x stop-service.sh
```
### 3.2 서비스 시작
```bash
# 서비스 시작
./start-service.sh
# 로그 확인
tail -f logs/app.log
# 프로세스 상태 확인
ps aux | grep "node server.js"
```
### 3.3 서비스 중지
```bash
# 서비스 중지
./stop-service.sh
```
## 4. 자동 시작 설정 (선택사항)
### 4.1 Task Scheduler 사용
1. **DSM 제어판****작업 스케줄러**
2. **작업 생성****사용자 정의 스크립트**
3. 설정:
- **작업 이름**: Jaryo Service Start
- **사용자**: root
- **스케줄**: 시스템 부팅 시
- **작업 설정**: `/volume1/web/jaryo/start-service.sh`
### 4.2 rc.local 사용 (고급 사용자)
```bash
# /etc/rc.local 파일 편집
sudo vi /etc/rc.local
# 다음 라인 추가
/volume1/web/jaryo/start-service.sh &
# 파일 저장 후 권한 설정
chmod +x /etc/rc.local
```
## 5. 방화벽 및 포트 설정
### 5.1 DSM 방화벽 설정
1. **DSM 제어판****보안****방화벽**
2. **방화벽 규칙 편집****규칙 생성**
3. 설정:
- **포트**: 3005 (애플리케이션 포트)
- **프로토콜**: TCP
- **소스**: 허용할 IP 범위
### 5.2 라우터 포트 포워딩 (외부 접속용)
라우터에서 포트 3005를 NAS의 IP로 포워딩 설정
## 6. 웹 서버 프록시 설정 (Web Station 사용)
### 6.1 Web Station 설정
1. **Web Station****가상 호스트****생성**
2. 설정:
- **도메인 이름**: your-domain.com (또는 IP)
- **포트**: 80 (또는 443 for HTTPS)
- **문서 루트**: `/volume1/web/jaryo`
- **HTTP 백엔드 서버**: `http://localhost:3005`
### 6.2 Apache 설정 (고급)
```apache
# /volume1/web/apache/conf/vhost/VirtualHost.conf
<VirtualHost *:80>
ServerName your-domain.com
DocumentRoot /volume1/web/jaryo
ProxyPreserveHost On
ProxyPass / http://localhost:3005/
ProxyPassReverse / http://localhost:3005/
<Directory /volume1/web/jaryo>
AllowOverride All
Require all granted
</Directory>
</VirtualHost>
```
## 7. 모니터링 및 유지보수
### 7.1 로그 모니터링
```bash
# 실시간 로그 확인
tail -f /volume1/web/jaryo/logs/app.log
# 로그 파일 크기 확인
du -h /volume1/web/jaryo/logs/app.log
# 로그 로테이션 설정 (logrotate 사용)
```
### 7.2 서비스 상태 확인
```bash
# 프로세스 확인
ps aux | grep "node server.js"
# 포트 사용 확인
netstat -tlnp | grep :3005
# 메모리 사용량 확인
top -p $(cat /volume1/web/jaryo/app.pid)
```
### 7.3 백업 설정
1. **Hyper Backup** 패키지 설치
2. `/volume1/web/jaryo` 폴더 백업 스케줄 설정
3. 데이터베이스 파일 (`jaryo.db`) 별도 백업 권장
## 8. 문제 해결
### 8.1 일반적인 문제들
**서비스가 시작되지 않는 경우:**
```bash
# Node.js 설치 확인
which node
node --version
# 의존성 재설치
cd /volume1/web/jaryo
rm -rf node_modules package-lock.json
npm install
# 권한 문제 확인
ls -la /volume1/web/jaryo/
chown -R admin:users /volume1/web/jaryo/
```
**포트 충돌 문제:**
```bash
# 포트 사용 확인
netstat -tlnp | grep :3005
# 다른 포트로 변경 (server.js 수정)
# const PORT = process.env.PORT || 3006;
```
**메모리 부족 문제:**
```bash
# 메모리 사용량 확인
free -h
# Node.js 메모리 제한 설정
# node --max-old-space-size=512 server.js
```
### 8.2 로그 분석
```bash
# 에러 로그만 확인
grep -i error /volume1/web/jaryo/logs/app.log
# 최근 100줄 확인
tail -100 /volume1/web/jaryo/logs/app.log
# 특정 시간대 로그 확인
grep "2024-01-15" /volume1/web/jaryo/logs/app.log
```
## 9. 보안 고려사항
1. **HTTPS 설정**: Let's Encrypt 인증서 사용
2. **방화벽 강화**: 필요한 포트만 개방
3. **정기 업데이트**: Node.js 및 패키지 업데이트
4. **백업**: 정기적인 데이터 백업
5. **모니터링**: 로그 모니터링 및 알림 설정
## 10. 성능 최적화
1. **PM2 사용**: 프로세스 관리자로 PM2 사용 고려
2. **캐싱**: 정적 파일 캐싱 설정
3. **압축**: gzip 압축 활성화
4. **CDN**: 정적 파일 CDN 사용 고려
---
**참고**: 이 가이드는 시놀로지 DSM 7.x 기준으로 작성되었습니다. 버전에 따라 일부 설정이 다를 수 있습니다.