Files
2nd/01_Archive/2026-04-20/계층형 아키텍처 (Layered Architecture).md

42 lines
4.6 KiB
Markdown

---
id: P-REINFORCE-AUTO-28439B
category: "10_Wiki/💡 Topics/Design & Experience"
confidence_score: 0.90
tags: [auto-reinforced]
last_reinforced: 2026-04-20
github_commit: "[P-Reinforce] Continuous Worker - 계층형 아키텍처 (Layered Architecture)"
---
# [[계층형 아키텍처 (Layered Architecture)|계층형 아키텍처 (Layered Architecture)]]
## 📌 한 줄 통찰 (The Karpathy Summary)
> 계층형 아키텍처(Layered Architecture), 또는 n-tier 아키텍처는 시스템을 수평적인 계층(Layer)들로 나누어 구성하는 전통적이고 영향력 있는 소프트웨어 설계 패턴입니다 [1, 2]. 각 계층은 특정한 책임을 가지며, 인접한 하위 계층하고만 소통하도록 통신을 제한하여 엄격한 관심사의 분리(Separation of Concerns)를 강제합니다 [2, 3]. 이 아키텍처의 주된 목표는 시스템을 명확히 구조화하여 개발, 테스트, 유지보수성을 단순화하고 모듈성을 향상시키는 것입니다 [2, 4].
## 📖 구조화된 지식 (Synthesized Content)
- **3계층 구조의 역할 분리:** 가장 보편적인 애플리케이션의 계층 구조는 3가지 영역으로 나뉘어 구현됩니다 [3, 5, 6].
- **프레젠테이션 계층 (Presentation Layer):** 사용자 인터페이스(UI)와 사용자 경험(UX) 로직을 전담하며, 데이터를 표시하고 사용자의 입력을 캡처합니다 (예: HTML, CSS, JavaScript 등) [3, 5, 7].
- **비즈니스 로직 계층 (Business Logic/Domain Layer):** 애플리케이션의 핵심 비즈니스 규칙과 워크플로우를 처리합니다 [5, 7]. 프레젠테이션 계층의 명령을 처리하고, 데이터 액세스 계층과 상호작용을 조정합니다 [3, 5].
- **데이터 액세스 계층 (Data Access/Persistence Layer):** 데이터베이스와 같은 외부 데이터 소스와의 통신(CRUD 작업 등)을 전담하여, 핵심 비즈니스 로직을 데이터 저장의 구체적 구현 방식으로부터 격리시킵니다 [3, 5, 7].
- **구현 원칙 및 모범 사례:**
- **엄격한 계층 통신 강제:** 한 계층은 바로 아래에 위치한 인접 계층하고만 통신해야 합니다 [3, 8]. 예를 들어 프레젠테이션 계층이 데이터 액세스 계층을 직접 호출하지 못하게 차단하여 강한 결합(Tight coupling)을 예방합니다 [8].
- **의존성 주입(DI) 활용:** 계층 간의 의존성을 직접 생성하지 않고 외부에서 주입받도록 하여 느슨한 결합(Loose coupling)과 향상된 테스트 용이성을 촉진합니다 [8, 9].
- **명확한 인터페이스 정의:** 각 계층 사이에 잘 정의된 인터페이스를 생성하여, 상위 계층에 영향을 주지 않고 하위 계층의 구현(예: 데이터베이스 종류 변경 등)을 유연하게 교체할 수 있도록 해야 합니다 [8].
- **장점 및 적용 사례:**
이 패턴은 구조가 잘 알려져 있어 구현 복잡도가 비교적 낮으며, 전통적인 엔터프라이즈 애플리케이션이나 3-Tier 시스템 구축에 이상적입니다 [9]. 각 책임을 독립적인 계층으로 격리시키기 때문에 모듈성과 재사용성이 높아지며, 특정 계층의 변화가 다른 계층에 미치는 파급 효과를 차단하여 결과적으로 각 계층별 독립적인 테스트와 유지보수가 매우 쉬워집니다 [2, 9, 10].
## ⚠️ 모순 및 업데이트 (Contradictions & RL Update)
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
- **정책 변화:** Design & Experience 분야의 자동 자산화 수행.
## 🔗 지식 연결 (Graph)
- **Related Topics:** [[관심사의 분리 (Separation of Concerns)|관심사의 분리 (Separation of Concerns)]], N-Tier 아키텍처 (N-Tier Architecture), [[의존성 주입 (Dependency Injection)|의존성 주입 (Dependency Injection)]], [[단일 책임 원칙 (SRP)|단일 책임 원칙 (SRP)]]
- **Projects/Contexts:** 엔터프라이즈 애플리케이션, 웹 애플리케이션 3계층 시스템 (3-Tier Systems)
- **Contradictions/Notes:** 소스에 따르면, 계층형 아키텍처는 명확한 분리를 제공해 주지만 레이어를 무겁게 만들면 오히려 시스템 관리가 비효율적일 수 있으므로, 계층을 얇게 유지(Keep layers thin)하고 인터페이스와 의존성 주입을 적극 활용하여 경계를 명확히 보호할 것을 권장하고 있습니다 [8, 9].
---
*Last updated: 2026-04-18*
- Raw Source: 00_Raw/2026-04-20/계층형 아키텍처 (Layered Architecture).md
---