중앙 관리자 플랫폼 — 여러 도메인을 한 허브에서
Next.js 16 + PostgreSQL 여러 풀로 운영자 허브를 짓는 8단계 강좌. AdminResourceTable · 감사로그 · OAuth · 백업까지.
- 난이도
- intermediate
- 강의
- 8
중앙 관리자 플랫폼 — 여러 도메인을 한 허브에서
여러 도메인 (블로그·마켓·앱·외부 SaaS) 을 운영하는 팀은 매 도메인마다 관리자 UI 를 따로 만들기 쉽습니다. 단기적으로는 빠르지만 3~6개월만 지나면 운영자가 페이지마다 UI 를 다시 배우고 개발자는 같은 boilerplate 를 반복합니다. 이 강좌는 한 Next.js 앱이 여러 PostgreSQL 풀 (도메인 DB) 에 직접 접속해 CRUD · 감사로그 · 백업 · OAuth 까지 감당하는 허브 구조를 8 단계로 따라갑니다.
누구를 위한 강좌인가
- 여러 사이드프로젝트 · 서비스를 하나의 관리자 허브 로 묶고 싶은 분
- React 19 + Next.js App Router 를 실전 규모로 써 보고 싶은 분
- 감사로그 · OAuth · 백업 자동화 등 "운영에 필요한 공통 기능" 을 한 번에 익히고 싶은 분
다 끝내면 가능한 것
- PostgreSQL 여러 풀을 한 앱에서 직접 orchestration
AdminResourceTable공통 컴포넌트로 페이지당 30~70 줄로 CRUD 구현logAdminActionfire-and-forget 감사로그 패턴- 카카오 · 네이버 OAuth 2 provider + 이메일 화이트리스트
pg_dump+ cron 자동 백업 + 7일 rolling retention- Playwright 매니페스트 자동 생성으로 수십 페이지 smoke 1 초 spec
단계 흐름
[1] 동기 ──▶ [2] 셋업 ──▶ [3] 여러 풀 ──▶ [4] 공통 테이블
│
▼
[8] E2E 매니페스트 ◀── [7] 백업 ◀── [6] 감사로그 ◀── [5] OAuth + 화이트리스트
전반부 (14) 는 기반 — 왜 모았고 어떻게 연결하는지. 후반부 (58) 는 운영 — 권한 · 추적 · 안정성.
단계 구성
- 왜 중앙 허브인가 — 도메인 N + 관리자 UI N 의 비용, 한 곳으로 묶었을 때의 이득
- 프로젝트 셋업 — Next 16 + TypeScript strict + shadcn/ui + Tailwind 4
- 여러 PostgreSQL 풀 연결 — 환경변수 규약 · 풀 싱글톤 · 쿼리 헬퍼
- AdminResourceTable SSOT — 공통 테이블 컴포넌트 · iconColor 맵 · 페이지네이션 URL-first
- OAuth 2 provider + 화이트리스트 — 카카오 · 네이버 · JWT 세션 쿠키
- 감사로그 (logAdminAction) —
audit_logs테이블 · reason 30자 강제 · 도메인별 viewer - 백업 자동화 —
pg_dump+node-cron+ 화이트리스트 테이블 30개 - E2E 매니페스트 + 배포 — Playwright 자동 매니페스트 + Docker standalone 배포
전제 — getting-started 강좌 + Node 20 / PostgreSQL 15 / Docker · nextjs-fullstack 강좌 (App Router 기초).
단계별 강의
다른 강좌
전체 보기 →- 처음 시작하는 개발 환경
- HTML/CSS/JS 부터 React, Next, Tailwind 까지
- Next.js 16 으로 첫 풀스택 앱 만들기
- Spring Boot 4 로 시작하는 백엔드
- Python · FastAPI · 데이터 파이프라인
- AI 시대의 개발 도구 — Claude Code · MCP · 디자인 도구
- Docker · Caddy · 클라우드 10단계 배포 옵션
- 로컬 LLM · pgvector · RAG 챗봇 만들기
- Tauri 2 — 데스크탑 · 모바일 한 코드베이스
- 테스트 전략과 품질 게이트
- 웹 보안의 기초 — JWT · OAuth · OWASP
- PostgreSQL 깊게 다루기 + Redis · Kafka
- 공공데이터 크롤러 만들기
- 모노레포 · SSOT · 계층 분리 사고