여러 애그리거트가 필요한 기능도메인 영역의 코드를 작성하다 보면, 한 애그리거트로 기능을 구현할 수 없는 경우가 있습니다. 대표적으로, 결제 금액 계산 로직이 있는데 다음과 같은 내용이 필요합니다.상품 애그리거트주문 애그리거트할인 쿠폰 애그리거트회원 애그리거트이때 생각해볼 수 있는 방법은 '주문 애그리거트'가 필요한 데이터를 모두 가지도록 한 뒤 할인 금액 계산 책임을 주문 애그리거트에 할당하는 방법입니다. 만약 이때, 특별 감사 세일을 적용해 한 달간 2% 추가 할인을 적용하면 어떻게 될까요? 이 할인 정책은 주문 애그리거트의 구성요소와 관련이 없음에도 주문 애그리거트의 코드를 수정해야 합니다. 이 경우 다음과 같은 문제점이 발생합니다.자신의 책임 범위를 넘어서는 기능을 구현하게 된다.외부에 대한 의존..
표현 영역의 책임은 크게 다음과 같습니다.사용자가 시스템을 사용할 수 있는 흐름(화면)을 제공하고 제어한다.사용자의 요청을 알맞은 응용 서비스에 전달하고 결과를 사용자에게 제공한다.사용자의 세션을 관리한다.값 검증값 검증은 표현 영역과 응용 서비스 두 곳에서 모두 수행할 수 있습니다. 원칙적으로는 모든 값에 대한 검증은 응용 서비스에서 처리합니다.표현 영역과 응용 서비스는 값 검사를 다음과 같이 나누어 수행할 수 있습니다.표현 영역 : 필수 값, 값의 형식, 범위 등을 검증응용 서비스 : 데이터의 존재 유무와 같은 논리적 오류를 검증하지만, 응용 서비스에서 필요한 값 검증과 논리적 값 검증을 모두 처리하면 작성할 코드가 늘어나는 불편함이 있지만, 응용 서비스의 완성도가 높아진다는 장점 또한 존재합니다. ..
앞선 포스팅에서는 도메인 영역과 관련해 살펴 보았습니다. 이 도메인이 제 기능을 하기 위해서는 사용자와 도메인을 연결해 주는 매개체가 필요하며 응용 영역과 표현 영역이 이 매개체 역할을 합니다. 이번 포스팅에서는 응용 영역에 대해 알아보겠습니다.응용 서비스응용 서비스는 사용자(클라이언트)가 요청한 기능을 실행합니다.주요 역할도메인 객체를 사용해 사용자의 역할을 처리트랜잭션 처리응용 서비스는 주로 도메인 객체 간의 흐름을 제어하기에 아래와 같이 단순한 형태를 가집니다.일반적인 기능public Result doSomeFunc(SomeReq req) { // 1. 리포지터리에서 애그리거트를 구한다. SomeAgg agg = someAggRepository.findById(req.getId()); checkN..
이번 포스팅에서는 자바의 ORM 표준인 JPA를 이용해 리포지터리와 애그리거트를 구현하는 방법에 대해 살펴보겠습니다. 앞선 포스팅에서 설명한 것처럼 리포지터리 인터페이스는 애그리거트와 같은 도메인 영역에 속하고, 이를 구현한 클래스는 인프라스트럭처 영역에 속합니다.가능하면 위와 같이 리포지터리 구현 클래스를 인프라스트럭처 영역에 위치시켜 인프라스트럭처에 대한 의존을 낮추는 것이 중요합니다.리포지터리 인터페이스는 애그리거트 루트를 기준으로 작성합니다.애그리거트를 수정한 결과를 저장소에 반영하는 메서드는 필요없습니다.JPA를 사용하면 트랜잭션 범위에서 변경한 데이터를 자동으로 DB에 반영합니다.JPA는 변경된 객체의 데이터를 DB에 반영하기 위해 UPDATE 쿼리를 실행합니다.매핑 구현애그리거트와 JPA 매..
계층 구조 아키텍처네 영역을 구성할 때 많이 사용하는 아키텍처는 아래와 같은 계층 구조입니다.계층 구조는 특성상 상위 계층에서 하위 계층으로의 의존만 존재하고 하위 계층은 상위 계층에 의존하지 않습니다. 하지만, 편리함을 위해 아래와 같이 응용 계층에서 인프라스트럭처 계층에 직접 의존하는 계층 구조를 가지기도 합니다.응용, 도메인 영역이 DB나 외부 시스템 연동을 위해 인프라스트럭처의 기능을 사용하므로, 위의 구조는 직관적으로 이해하기 쉽습니다. 하지만, 이 경우표현, 응용, 도메인 계층이 상세한 구현 기술을 다루는 인프라스트럭처 계층에 종속되게 됩니다. 도메인의 "가격 계산 규칙"을 예시로 들어보겠습니다.우선, Dr∞ls라는 룰 엔진을 통해 계산 로직을 수행하는 인프라스트럭처 영역의 코드입니다.p..
도메인이란?도메인이란해결하고자 하는 문제의 영역을 말합니다. 한 도메인은 다시 하위 도메인으로 나눌 수 있습니다.예를 들어, "온라인 서점"이라는 도메인은 다음과 같은 하위 도메인으로 나눌 수 있습니다.회원주문결제배송카탈로그리뷰정산혜택도메인 모델도메인 모델이란특정 도메인을 개념적으로 표현한 것입니다. 주문 도메인을 예시로 객체 모델로 구성하면 다음과 같이 나타낼 수 있습니다.도메인을 이해하려면 도메인이 제공하는 기능과 도메인의 주요 데이터 구성을 파악해야 합니다. 이런 면에서 기능과 데이터를 함께 보여주는 객체 모델은 도메인을 모델링하기에 매우 적합합니다.물론, 객체가 아닌 상태 다이어그램, 수학 공식 등을 통해 모델링하는 방법도 존재합니다. 즉, 도메인을 이해하는 데 도움이 된다면 표현 방식이 무엇인지..
내 블로그 - 관리자 홈 전환 |
Q
Q
|
---|---|
새 글 쓰기 |
W
W
|
글 수정 (권한 있는 경우) |
E
E
|
---|---|
댓글 영역으로 이동 |
C
C
|
이 페이지의 URL 복사 |
S
S
|
---|---|
맨 위로 이동 |
T
T
|
티스토리 홈 이동 |
H
H
|
단축키 안내 |
Shift + /
⇧ + /
|
* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.