/////
Search
Duplicate
1️⃣

도메인 모델과 경계

: 도메인 모델을 처음 만들 때 빠지기 쉬운 함정은 도메인을 완벽하게 표현하는 단일 모델을 만드는 시도를 하는 것
: 1장에서 말한 것처럼 한 도메인은 다시 여러 하위 도메인으로 구분되기 때문에 한 개의 모델로 여러 하위 도메인을 모두 표현하려고 시도하면 오히려 모든 하위 도메인에 맞지 않는 모델을 만들게 된다.
: 예를 들어 상품이라는 모델을 생각해 보자, 카탈로그에서 상품, 재고 관리에서 상품, 주문에서 상품, 배송에서 상품은 각각 이름만 같지 실제로 의미하는 것이 다르다.
: 카탈로그에서의 상품은 상품 이미지, 상품명, 상품 가격, 옵션 목록, 상세 설명과 같은 상품 정보가 위주라면 재고 관리에서는 실존하는 개별 객체를 추적하기 위한 목적으로 상품을 사용한다.
: 즉 카탈로그에서는 물리적으로 한 개인 상품이 재고 관리에서는 여러 개 존재할 수 있다.
: 논리적으로 같은 존재처럼 보이지만 하위 도메인에 따라 다른 용어를 사용하는 경우도 있다.
: 카탈로그 도메인에서의 상품이 검색 도메인에서는 문서로 불리기도 한다. 비슷하게 시스템을 사용하는 사람을 회원 도메인에서는 회원이라고 부르지만, 주문 도메인에서는 주문자라고 부르고 배송 도메인에서는 보낼 사람이라고 부른다.
: 이렇게 하위 도메인마다 같은 용어라도 그 의미가 다르고 같은 대상이라도 지칭하는 용어가 다를 수 있기 때문에 한 개의 모델로 모든 하위 도메인을 표시하려는 시도는 올바른 방법이 아니다.
: 하위 도메인마다 사용하는 용어가 다르기 때문에 올바른 도메인 모델을 개발하려면 하위 도메인마다 모델을 만들어야 한다. 각 모델은 명시적으로 구분되는 경계를 가져서 섞이지 않도록 해야 한다.
: 여러 하위 도메인의 모델이 섞이기 시작하면 모델의 의미가 약해질 뿐만 아니라 여러 도메인의 모델이 서로 얽히기 때문에 각 하위 도메인별로 다르게 발전하는 요구사항을 모델에 반영하기 어려워 진다.
: 모델은 특정한 맥락 하에서 완전한 의미를 가지게 된다. 같은 제품이더라도 카탈로그 컨텍스트와 재고 컨텍스트에서의 그 의미가 다르듯이 이렇게 구분되는 경계를 갖는 컨텍스트를 DDD에서는 바운디드 컨텍스트라고 부른다.