# SAM 서버 접근 권한 관리 ## 개요 SAM 시스템의 서버 및 데이터베이스 접근 권한을 관리합니다. 서버 관리자는 1명이며, 외부 인원에게는 임시로 접근을 허용하고 작업 완료 후 차단합니다. **최종 업데이트:** 2026-03-05 --- ## 서버 정보 | 구분 | 호스트 | SSH alias | 용도 | |------|--------|-----------|------| | 운영 (prod) | 211.117.60.189 | `sam-prod` | API + React 운영 배포 | | CI/CD | 114.203.209.83 | `sam-cicd` | Jenkins + React 개발 배포 | --- ## OS 계정 현황 ### sam-prod (운영서버) | 계정 | 용도 | 상태 | |------|------|------| | `hskwon` | 서버 관리자 (배포, 운영) | 활성 | | `pro` | 외부 작업자 임시 접근용 | **잠금** | ### sam-cicd (CI/CD 서버) | 계정 | 용도 | 상태 | |------|------|------| | `hskwon` | 서버 관리자 | 활성 | | `pro` | 외부 작업자 임시 접근용 | **잠금** | --- ## OS 계정 잠금/해제 외부 작업자에게 서버 접근이 필요한 경우, 작업 시간 동안만 해제하고 완료 후 다시 잠금합니다. ```bash # 계정 잠금 sudo usermod -L pro # 계정 해제 sudo usermod -U pro # 상태 확인 (비밀번호 필드 앞에 ! 있으면 잠금 상태) sudo passwd -S pro ``` ### 임시 접근 절차 1. 작업 요청 접수 및 범위 확인 2. `sudo usermod -U pro` 로 해제 3. 작업 완료 확인 4. `sudo usermod -L pro` 로 잠금 5. 작업 내용 기록 --- ## DB 계정 현황 ### sam-prod (운영서버 MySQL 8.4) | 계정 | 인증 플러그인 | 접근 DB | 용도 | |------|-------------|---------|------| | `codebridge@localhost` | caching_sha2_password | sam, sam_stage, sam_stat, codebridge | 애플리케이션 (.env) | | `hskwon@localhost` | caching_sha2_password | 전역 관리자 + sam | 서버 관리자 | | `pro@localhost` | caching_sha2_password | sam, sam_stage, sam_stat, codebridge | 외부 작업자용 | ### sam-cicd (CI/CD 서버 MySQL 8.4) | 계정 | 인증 플러그인 | 접근 DB | 용도 | |------|-------------|---------|------| | `hskwon@localhost` | caching_sha2_password | 전역 관리자 | 서버 관리자 | | `pro@localhost` | caching_sha2_password | sam, sam_stage, sam_stat, codebridge, gitea | 외부 작업자용 | > **참고:** cicd 서버에는 `codebridge` DB 계정이 없음 (애플리케이션이 다른 계정 사용) --- ## DB 계정 관리 ### 계정 잠금/해제 (MySQL) ```sql -- 계정 잠금 ALTER USER 'pro'@'localhost' ACCOUNT LOCK; -- 계정 해제 ALTER USER 'pro'@'localhost' ACCOUNT UNLOCK; -- 상태 확인 SELECT user, host, account_locked FROM mysql.user WHERE user = 'pro'; ``` ### 인증 플러그인 변경 MySQL 8.4에서는 `mysql_native_password`가 제거되었으므로 `caching_sha2_password`를 사용합니다. ```sql ALTER USER 'username'@'localhost' IDENTIFIED WITH caching_sha2_password BY '비밀번호'; FLUSH PRIVILEGES; ``` ### PhpStorm 접속 시 주의사항 - SSH 터널 필수 (MySQL이 localhost만 허용) - Host: `localhost` (127.0.0.1 아님) - `caching_sha2_password` 사용 시 Advanced 탭에서 `allowPublicKeyRetrieval = true` 설정 필요 --- ## 배포 계정 관리 ### Jenkins 배포 흐름 | 프로젝트 | main | develop | |----------|------|---------| | **api** | Jenkins (Stage + Production) | post-update hook (Jenkins 미관여) | | **react** | Jenkins (Stage + Production) | Jenkins (Development) | - 배포 SSH 계정: `hskwon` (deploy-ssh-key 크레덴셜) - Slack 알림: `#deploy_api`, `#deploy_react` --- ## 관리 정책 1. **서버 관리자 1명 원칙** — 여러 명이 동시에 관리하지 않음 2. **임시 접근만 허용** — 외부 작업자는 필요 시에만 OS/DB 계정 해제 3. **작업 완료 후 즉시 잠금** — 해제 상태로 방치하지 않음 4. **DB 접근은 SSH 터널 경유** — 외부에서 MySQL 직접 접근 불가 (localhost 바인딩) --- ## 참고 - API 보안 가이드: [security-policy.md](./security-policy.md) - Docker 설정: [docker-setup.md](./docker-setup.md) - 원격 근무 설정: [remote-work-setup.md](./remote-work-setup.md) --- **작성일:** 2026-03-05 **버전:** 1.0 **담당자:** SAM Infrastructure Team