89 lines
9.9 KiB
Markdown
89 lines
9.9 KiB
Markdown
---
|
|
id: P-REINFORCE-WIKI-EC57F85A
|
|
title: "바운디드 컨텍스트 (Bounded Context)"
|
|
category: "10_Wiki/💡 Topics/02_Architecture_Principles"
|
|
status: verified
|
|
canonical_id: ""
|
|
aliases: []
|
|
duplicate_of: ""
|
|
source_trust_level: A
|
|
confidence_score: 0.95
|
|
tags: ['Bounded Context']
|
|
raw_sources: ["Datacollector_MAC/out_wiki/바운디드 컨텍스트 (Bounded Context).md"]
|
|
last_reinforced: 2026-05-02
|
|
github_commit: ""
|
|
---
|
|
|
|
# [[바운디드 컨텍스트 (Bounded Context)]]
|
|
|
|
## 📌 Brief Summary
|
|
바운디드 컨텍스트(Bounded Context)는 도메인 주도 설계(DDD)에서 거대하고 복잡한 비즈니스 도메인을 관리하기 쉽도록 분할한 독립적인 하위 도메인 경계를 의미합니다 [1]. 각 컨텍스트는 고유한 모델과 유비쿼터스 언어(Ubiquitous Language)를 보유하여 일관성을 유지하며 독립적으로 구현 및 진화할 수 있습니다 [1-3]. 대규모 시스템의 코드베이스를 읽을 때, 이러한 비즈니스 중심의 경계를 먼저 파악하는 것은 상세 로직을 해독하기 위한 강력한 인지적 기반을 제공합니다 [4].
|
|
|
|
## 📖 Core Content
|
|
|
|
- **비즈니스 기반의 경계 분리와 독립성**: 바운디드 컨텍스트는 복잡한 시스템을 '주문 관리', '고객 지원', '결제 처리' 등 비즈니스 기능(기능별 모듈)을 기준으로 분리하여 명확한 경계를 설정합니다 [1, 5]. 각 컨텍스트는 모델이 서로 겹치거나 영향을 주지 않도록 독립성을 보장하여 아키텍처를 깔끔하게 유지합니다 [3].
|
|
- **코드베이스 독해를 위한 인지적 기반**: 도메인 주도 설계가 적용된 코드베이스는 기술적인 기능이 아닌, 바운디드 컨텍스트라는 비즈니스 용어를 중심으로 폴더(디렉토리)가 구성됩니다 [4]. 엔지니어는 개별 코드의 상세 로직에 매몰되기 전에 이 구조적 특징을 파악함으로써 전체 비즈니스의 의도와 맥락을 먼저 이해하는 인지적 기반을 다질 수 있습니다 [4].
|
|
- **유비쿼터스 언어(Ubiquitous Language)를 통한 의미의 명확화**: 컨텍스트 내부에서는 비즈니스 이해관계자와 개발자가 공통으로 사용하는 유비쿼터스 언어가 일관되게 적용됩니다 [3, 6]. 이는 규칙이나 컨텍스트가 어디에 적용되는지에 대한 혼란(ambiguity)을 줄이고, 코드 및 문서 내에서 이해와 소통을 극대화합니다 [6, 7].
|
|
- **유지보수성과 확장성(Scalability)**: 각 바운디드 컨텍스트는 다른 시스템을 방해하지 않고 개별적으로 처리(단위 테스트, 버그 수정 등)될 수 있으므로 유지보수가 쉽습니다 [8]. 또한 비즈니스나 기술적 요구가 변화함에 따라 새로운 컨텍스트를 쉽게 추가할 수 있어 전체 시스템의 파괴 없이 안전하게 규모를 확장할 수 있습니다 [8].
|
|
- **모듈형 모놀리스(Modular Monolith) 구현의 핵심**: 바운디드 컨텍스트는 마이크로서비스뿐만 아니라 모듈형 모놀리스를 구현할 때도 필수적입니다 [6]. 모놀리스 내에서 개별 비즈니스 역량을 담는 모듈을 분리하고 내부 응집도를 높이며, 결합도를 최소화하는 기준이 됩니다 [6, 9].
|
|
|
|
## ⚖️ Trade-offs & Caveats
|
|
소스에 관련 정보가 부족합니다. (단, 바운디드 컨텍스트들이 완전히 분리되어 작동하기 때문에, 여러 컨텍스트 간의 상호 관계(Interrelationships)를 명시적으로 정의하고 조율하기 위해서는 '컨텍스트 매핑(Context Mapping)'이라는 추가적인 가이드 장치가 수반되어야 한다는 점이 제한적으로 언급되어 있습니다 [3, 7].)
|
|
|
|
## 🔗 Knowledge Connections
|
|
|
|
### Related Concepts
|
|
|
|
#### [설계 철학/아키텍처]
|
|
- [[도메인 주도 설계 (DDD)]]
|
|
- 연결 이유: 바운디드 컨텍스트는 복잡한 비즈니스 로직을 소프트웨어의 중심에 두는 DDD(Domain-Driven Design)의 가장 핵심적인 설계 패턴(하위 도메인 분할)이기 때문입니다 [1, 10].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 소프트웨어 시스템이 기술 스택 중심이 아니라 실제 비즈니스 도메인(현실 세계)을 중심으로 모델링되고 코드베이스가 구축되는 근본 원리를 이해할 수 있습니다 [5, 10].
|
|
|
|
- [[마이크로서비스 아키텍처 (Microservices Architecture)]]
|
|
- 연결 이유: 바운디드 컨텍스트는 거대하고 단일한 시스템을 독립적으로 배포 및 확장 가능한 마이크로서비스나 모듈형 모놀리스로 분해할 때 기준이 되는 '비즈니스 도메인 경계'를 제공하기 때문입니다 [6, 11].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 거대한 코드베이스를 상호 독립적인 서비스들로 나눌 때 데이터와 기능이 어떻게 묶여야 결합도를 낮출 수 있는지에 대한 시스템 분산 전략을 파악할 수 있습니다 [6, 11, 12].
|
|
|
|
#### [구조/구현 패턴]
|
|
- [[유비쿼터스 언어 (Ubiquitous Language)]]
|
|
- 연결 이유: 하나의 바운디드 컨텍스트 내의 모델 순수성을 유지하기 위해 모든 구성원(개발자, 비즈니스 전문가)이 코드와 대화에서 공통으로 사용하는 어휘집이기 때문입니다 [3, 10].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 코드베이스 내부의 변수, 함수, 클래스 명명 규칙이 어떤 비즈니스적 합의를 거쳐 지어졌는지 명확한 맥락을 파악할 수 있습니다 [3, 6, 13].
|
|
|
|
- [[애그리거트 (Aggregates)]]
|
|
- 연결 이유: 바운디드 컨텍스트(폴더) 내부를 구성하는 DDD의 세부 설계 패턴 중 하나로, 단일 단위로 취급되는 도메인 객체의 군집이기 때문입니다 [1, 4].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 바운디드 컨텍스트 내부의 여러 객체(엔티티 등)들이 어떻게 트랜잭션의 일관성을 유지하며 그룹화되어 있는지 세부적인 코드 구현 패턴을 추적할 수 있습니다 [1, 4].
|
|
|
|
### Deeper Research Questions
|
|
|
|
- 여러 개의 바운디드 컨텍스트가 상호작용해야 할 때, 컨텍스트 매핑(Context Mapping)은 코드베이스에서 어떠한 인터페이스나 통신 규약으로 구체화되는가?
|
|
- 대규모 레거시 모놀리스 코드를 분석하여 바운디드 컨텍스트 단위로 재구성(모더나이제이션)할 때, 숨겨진 데이터 의존성을 어떻게 안전하게 끊어낼 수 있는가?
|
|
- 하향식(Top-Down) 또는 상향식(Bottom-Up)으로 코드를 탐색할 때, 바운디드 컨텍스트 폴더 구조는 정보 추적 경로의 인지적 부하를 어떻게 감소시키는가?
|
|
- 유비쿼터스 언어가 서로 다른 바운디드 컨텍스트에서 중복되거나 다르게 해석될 때(예: '고객'이라는 단어의 의미 충돌), 코드 명명 규칙과 데이터 모델은 이를 어떻게 구분하는가?
|
|
- 바운디드 컨텍스트 내부를 구성하는 애그리거트(Aggregates), 엔티티(Entities), 값 객체(Value Objects) 간의 의존성 흐름을 가장 효율적으로 파악하는 코드 리딩 순서는 무엇인가?
|
|
|
|
### Practical Application Contexts
|
|
|
|
- **Implementation:** 비즈니스 기능을 코드로 구현할 때 특정 기능에 필요한 리소스와 클래스를 모두 하나의 패키지(컨텍스트) 안에 집중시켜 결합도를 낮추고 모듈화된 구현을 진행합니다 [3, 6, 14].
|
|
- **System Design:** 이커머스 등 복잡한 소프트웨어 시스템을 설계할 때 '주문 처리', '인벤토리', '사용자 관리' 등 각각의 컨텍스트 경계를 명확히 분리하여, 서로 영향을 주지 않는 모듈형 모놀리스나 마이크로서비스 구조를 도출합니다 [2, 5, 6].
|
|
- **Operation / Maintenance:** 개별 부분이 완벽히 분리되어 있으므로 시스템 유지보수 시 버그가 발생한 영역의 바운디드 컨텍스트 내에서만 유닛 테스트 및 수정 작업을 진행할 수 있어 안정적인 운영이 가능합니다 [8].
|
|
- **Learning Path:** 복잡한 대규모 코드베이스에 온보딩하는 개발자는 가장 먼저 코드의 디렉토리(폴더)가 어떤 비즈니스 바운디드 컨텍스트로 분류되어 있는지 파악함으로써 시스템 설계 의도를 거시적으로 인지하고 코드 독해에 착수합니다 [4].
|
|
- **My Project Relevance:** 방대한 레거시 또는 마이크로서비스 코드를 분석하거나 리뷰해야 할 때, 코드가 철저하게 비즈니스 도메인(바운디드 컨텍스트)을 기준으로 응집력을 갖추고 있는지 평가하고 분리하는 리팩토링 전략을 수립하는 데 적용할 수 있습니다.
|
|
|
|
### Adjacent Topics
|
|
|
|
- [[클린 아키텍처 (Clean Architecture)]]
|
|
- 확장 방향: 비즈니스 중심의 바운디드 컨텍스트를 구현할 때, 핵심 도메인 비즈니스 로직을 외부의 데이터베이스나 프레임워크로부터 독립시키고 보호하는 의존성 규칙(Dependency Rule)에 대해 추가로 학습합니다 [4, 15].
|
|
- [[코드베이스 오리엔테이션 맵 (Codebase Orientation Map)]]
|
|
- 확장 방향: 식별된 바운디드 컨텍스트 단위의 디렉토리 구조와 파일 간의 관계를 한눈에 볼 수 있도록 시각화하여, 팀원들의 시스템 구조 파악과 코드 탐색 효율성을 극대화하는 문서화 전략을 탐구합니다 [16, 17].
|
|
|
|
---
|
|
*Last updated: 2026-05-02*
|
|
## 🧪 검증 상태 (Validation)
|
|
- **정보 상태:** verified
|
|
- **출처 신뢰도:** A
|
|
- **검토 이유:** Datacollector에서 자동 추출된 위키 데이터의 초기 통합.
|
|
|
|
## 🧬 중복 검사 (Duplicate Check)
|
|
- **기존 유사 문서:** [[바운디드 컨텍스트 (Bounded Context).md]]
|
|
- **처리 방식:** UPDATE
|
|
- **처리 이유:** 기존 문서 내용 보강 및 v3.1 표준 적용
|