DDD Start!
애그리거트, 엔티티, 리포지토리 등 DDD의 핵심 패턴을 이용해서 도메인 모델을 구현하는 방법을 설명한다. 도메인 모델의 트랜잭션 충돌을 처리하는 기법(선점 잠금, 비선점 잠금)을 살펴보고, 도메인 이벤트를 이용해서 도메인 영역 간의 의존을 낮추는 방법과 명령 모델과 조회 모델을 나누는 기법에 대해서도 배운다.
스프링과 JPA를 이용해서 실제 동작하는 코드를 함께 제공하고 있으므로 DDD를 학습하고 싶은 개발자에게 좋은 길잡이가 될 것이다.
작가정보
목차
- CHAPTER 1 도메인 모델 시작
도메인… ………………………………………………………………………… 1
도메인 모델… …………………………………………………………………… 3
도메인 모델 패턴………………………………………………………………… 6
도메인 모델 도출……………………………………………………………… 10
엔티티와 밸류………………………………………………………………… 17
엔티티……………………………………………………………………………… 18
엔티티의 식별자 생성…………………………………………………………… 20
밸류 타입… ……………………………………………………………………… 22
엔티티 식별자와 밸류 타입……………………………………………………… 29
도메인 모델에 set 메서드 넣지 않기…………………………………………… 30
도메인 용어…………………………………………………………………… 34
CHAPTER 2 아키텍처 개요
네 개의 영역…………………………………………………………………… 37
계층 구조 아키텍처…………………………………………………………… 40
DIP……………………………………………………………………………… 44
DIP 주의사항……………………………………………………………………… 50
DIP와 아키텍처…………………………………………………………………… 52
도메인 영역의 주요 구성요소… …………………………………………… 54
엔티티와 밸류… ………………………………………………………………… 55
애그리거트………………………………………………………………………… 58
리포지터리………………………………………………………………………… 61
요청 처리 흐름………………………………………………………………… 65
인프라스트럭처 개요… ……………………………………………………… 66
모듈 구성… …………………………………………………………………… 68
CHAPTER 3 애그리거트
애그리거트…………………………………………………………………… 71
애그리거트 루트……………………………………………………………… 75
도메인 규칙과 일관성…………………………………………………………… 76
애그리거트 루트의 기능 구현…………………………………………………… 80
트랜잭션 범위…………………………………………………………………… 82
리포지터리와 애그리거트…………………………………………………… 85
ID를 이용한 애그리거트 참조……………………………………………… 87
ID를 이용한 참조와 조회 성능…………………………………………………… 92
애그리거트 간 집합 연관…………………………………………………… 94
애그리거트를 팩토리로 사용하기…………………………………………… 98
CHAPTER 4 리포지터리와 모델구현(JPA 중심)
JPA를 이용한 리포지터리 구현…………………………………………… 103
모듈 위치……………………………………………………………………… 104
리포지터리 기본 기능 구현…………………………………………………… 104
매핑 구현……………………………………………………………………… 109
엔티티와 밸류 기본 매핑 구현… …………………………………………… 109
기본 생성자… ………………………………………………………………… 112
필드 접근 방식 사용…………………………………………………………… 114
AttributeConverter를 이용한 밸류 매핑 처리……………………………… 115
밸류 컬렉션: 별도 테이블 매핑……………………………………………… 119
밸류 컬렉션: 한 개 칼럼 매핑………………………………………………… 122
밸류를 이용한 아이디 매핑…………………………………………………… 123
별도 테이블에 저장하는 밸류 매핑… ……………………………………… 125
밸류 컬렉션을 @Entity로 매핑하기… ……………………………………… 129
ID 참조와 조인 테이블을 이용한 단방향 M-N 매핑………………………… 134
애그리거트 로딩 전략………………………………………………………… 134
애그리거트의 영속성 전파…………………………………………………… 138
식별자 생성 기능……………………………………………………………… 139
CHAPTER 5 리포지터리의 조회 기능(JPA 중심)
검색을 위한 스펙……………………………………………………………… 143
스펙 조합……………………………………………………………………… 145
JPA를 위한 스펙 구현……………………………………………………… 146
JPA 스펙 구현………………………………………………………………… 147
AND/OR 스펙 조합을 위한 구현…………………………………………… 150
스펙을 사용하는 JPA 리포지터리 구현……………………………………… 153
정렬 구현……………………………………………………………………… 155
페이징과 개수 구하기 구현………………………………………………… 160
조회 전용 기능 구현………………………………………………………… 162
동적 인스턴스 생성…………………………………………………………… 162
하이버네이트 @Subselect 사용……………………………………………… 165
CHAPTER 6 응용 서비스와 표현 영역
표현 영역과 응용 영역……………………………………………………… 169
응용 서비스의 역할…………………………………………………………… 171
도메인 로직 넣지 않기………………………………………………………… 173
응용 서비스의 구현…………………………………………………………… 176
응용 서비스의 크기… ………………………………………………………… 176
응용 서비스의 인터페이스와 클래스………………………………………… 180
메서드 파라미터와 값 리턴…………………………………………………… 181
표현 영역에 의존하지 않기…………………………………………………… 185
트랜잭션 처리………………………………………………………………… 187
도메인 이벤트 처리…………………………………………………………… 188
표현 영역……………………………………………………………………… 190
값 검증………………………………………………………………………… 193
권한 검사……………………………………………………………………… 197
조회 전용 기능과 응용 서비스……………………………………………… 201
CHAPTER 7 도메인 서비스
여러 애그리거트가 필요한 기능…………………………………………… 203
도메인 서비스………………………………………………………………… 205
도메인 서비스의 패키지 위치………………………………………………… 209
도메인 서비스의 인터페이스와 클래스……………………………………… 210
CHAPTER 8 애그리거트 트랜잭션 관리
애그리거트와 트랜잭션……………………………………………………… 213
선점 잠금……………………………………………………………………… 215
선전 잠금과 교착 상태………………………………………………………… 217
비선점 잠금…………………………………………………………………… 218
강제 버전 증가………………………………………………………………… 227
오프라인 선점 잠금…………………………………………………………… 228
오프라인 선점 잠금을 위한 LockManager 인터페이스와 관련 클래스… 230
DB를 이용한 LockManager 구현… ………………………………………… 233
CHAPTER 9 도메인 모델과 BOUNDED CONTEXT
도메인 모델과 경계…………………………………………………………… 241
BOUNDED CONTEXT……………………………………………………… 242
BOUNDED CONTEXT의 구현…………………………………………… 245
BOUNDED CONTEXT 간 통합…………………………………………… 248
BOUNDED CONTEXT 간 관계…………………………………………… 256
컨텍스트 맵…………………………………………………………………… 259
CHAPTER 10 이벤트
시스템 간 강결합의 문제… ………………………………………………… 261
이벤트 개요… ………………………………………………………………… 265
이벤트 관련 구성요소… ……………………………………………………… 266
이벤트의 구성… ……………………………………………………………… 266
이벤트 용도… ………………………………………………………………… 269
이벤트 장점… ………………………………………………………………… 270
이벤트, 핸들러, 디스패처 구현……………………………………………… 271
이벤트 클래스… ……………………………………………………………… 271
EventHandler 인터페이스… ………………………………………………… 273
이벤트 디스패처인 Events 구현……………………………………………… 275
흐름 정리……………………………………………………………………… 279
AOP를 이용한 Events.reset() 실행…………………………………………… 281
동기 이벤트 처리 문제……………………………………………………… 283
비동기 이벤트 처리…………………………………………………………… 284
로컬 핸들러의 비동기 실행…………………………………………………… 285
메시징 시스템을 이용한 비동기 구현……………………………………… 290
이벤트 저장소를 이용한 비동기 처리……………………………………… 291
이벤트 저장소 구현… ………………………………………………………… 293
이벤트 저장을 위한 이벤트 핸들러 구현…………………………………… 299
REST API 구현………………………………………………………………… 301
포워더 구현…………………………………………………………………… 304
이벤트 적용 시 추가 고려사항……………………………………………… 307
CHAPTER 11 CQRS
단일 모델의 단점……………………………………………………………… 311
CQRS………………………………………………………………………… 312
웹과 CQRS…………………………………………………………………… 317
CQRS 장단점………………………………………………………………… 318
책 속으로
서문 중에서
처음 DDD(Domain Driven Design: 도메인 주도 설계)를 접한 건 2006년의 일이다. 이때, 에릭 에반스가 쓴 "도메인 주도 설계" 책을 처음 읽었다. 나는 그 전까지 컨트롤러-서비스-DAO-DTO를 이용해서 웹 어플리케이션을 개발하고 있었는데, DDD 책을 읽고 새로운 세상을 만난 기분이 들었다. 그 뒤로 이 주제의 관련 지식을 학습하고 나름 적용도 해보면서 DDD를 익히기 시작했다. DDD를 시도할 때 어려웠던 것은 DDD 자체를 이해하는 것이었다. 지금도 DDD를 완전히 마스터했다고 할 수 없지만, 처음 책을 읽을 때엔 잘 이해되지 않는 내용이 많았다. 그 덕에 같은 책을 여러 차례 반복해서 읽어가면서 조금씩 이해의 폭을 넓혔다.
두 번째로 어려웠던 것은 구현에 대한 것이었다. 그 당시만 해도 DDD에 대한 구현 예제가 많지 않았다. DDD 자체에 대한 이해가 부족한 상황에서 참고할 만한 코드도 없었기에 좌충우돌하면서 구현을 시도했다. 그 사이 많은 시간이 흘렀지만 여전히 많은 개발자가 DDD와 도메인 모델을 구현하는 것을 어려워하고 있다. DDD가 어렵게 느껴지는 여러 이유가 있겠지만, 그 중 하나는 징검다리 역할을 할 입문서가 없는 것이라 생각한다. 에릭 에반스의 책은 처음 DDD를 접하는 개발자가 보기엔 다소 어렵고, 어던 책은 아쉽게도 번역서가 없거나 DDD 입문자에게 도움이 되지 않는다. 이 책을 쓴 계기는 바로 여기에 있다. 프로그래밍 언어 입문서와 깊이 있는 내용을 다루는 책이 따로 있는 것처럼, DDD도 입문자를 위한 책이 따로 필요하다 생각한다.이 책은 처음 DDD를 접하는 개발자가 깊이 있게 DDD를 학습하기 전에 DDD의 기본을 쌓을 수 있는 징검다리 역할을 한다. (중략)
출판사 서평
대상 독자
이 책은 DDD를 처음 접하는 개발자를 위한 책이며, DDD 입문자를 위한 책이다. DDD 고수가 되는 법을 알려주는 책은 아니다. 이미 DDD 기초를 마스터했다면 다른 책을 통해 DDD의 심오함을 느끼기 바란다. 아직 DDD는 모르지만 DDD에 관심이 있다면 이 책을 통해서 호기심을 채울 수 있을 것이다.
이 책을 읽는데 개발 경력은 크게 중요하지 않지만, 적어도 3~4년의 개발 경험이 있으면 책의 내용을 이해하는데 도움이 된다. 신입이라면 이 책에서 말하는 일부 내용이 와닿지 않을 수도 있다.
이 책 예제 코드에서 사용하는 언어는 자바이다. 예제에서 사용한 기술로는 스프링 MVC와 JPA(ORM)가 있다. 이 두 기술 자체를 잘 몰라도 책에서 설명하는 내용을 따라가는데 어려움은 없지만 기술에 대한 개요 정도를 알고 있다면 책을 더 잘 이해하는데 도움이 된다. 특히 SQL에만 익숙하다면 JPA가 뭔지 정도는 학습을 하고 이 책을 읽기를 바란다.
DDD가 객체를 기반으로 도메인 모델을 구축하는 내용을 다루지만 객체 지향의 캡슐화, 추상화, 다형성과 같은 주제가 익숙하지 않아도 책을 읽고 이해하는데 큰 문제는 되지 않는다.
이 책의 구성
이 책은 도메인 모델을 이용해서 어플리케이션을 구현하는데 필요한 내용을 다룬다. 전체는 11장으로 구성되어 있는데, 도입부인 1장과 2장에서는 도메인 모델을 구현할 때 알아야 할 기본 내용을 다룬다. 1장에서는 도메인 모델이 무엇인지 알아보고 엔티티와 밸류에 대해 알아본다. 2장은 상위 수준에서 아키텍처의 네 영역과 DIP패턴을 설명하고, 도메인 영역의 구성 요소에 대해 살펴본다.
3장부터 5장은 애그리것과 리포지토리를 설명한다. 애그리것은 복잡한 도메인 모델을 관리 가능한 단위로 묶어주는 역할을 담당하는데 3장에서 애그리것이 무엇이고 구현을 어떻게 하는지 알아본다. 4장에서는 애그리것의 논리적인 저장소인 리포지토리를 구현하는 방법을 알아보고 5장에서는 검색 조건을 위한 스펙, 정렬, 페이징 등 리포지토리의 조회 기능을 구현해본다.
6장은 응용 서비스와 표현 영역에 대해 설명한다. 응용 서비스가 어떻게 도메인 모델을 사용하고 어떤 역할을 수행하는지 알아보고 표현 영역과 응용 서비스의 연동에 대해 설명한다.
7장은 도메인 영역의 구성 요소 중 하나인 도메인 서비스가 필요한 이유와 구현에 대해 설명한다.
8장에서는 애그리것의 트랜잭션 범위에 대해 살펴보고, 애그리것의 트랜잭션 처리를 위해 DBMS를 이용한 선점 잠금과 버전을 이용한 비선점 잠금을 구현하는 방법을 소개한다.
9장은 애그리것과 더불어 가장 중요한 개념 중 하나인 바운디드 컨텍스트에 대한 내용을 다룬다. 바운디드 컨텍스트가 무엇이고, 각 컨텍스트의 통합과 관계에 대해 배워본다.
10장과 11장은 각각 이벤트와 CQRS에 대해 설명한다. 10장은 도메인 이벤트를 이용해서 시스템의 결합도를 낮추고 기능을 확장하는 방법을 설명하고, 비동기로 이벤트를 처리하는 몇 가지 구현 방법을 살펴본다. 11장은 CQRS과 무엇이고 이를 통해 어떤 효과를 얻을 수 있는 설명한다.
예제 코드 다운로드
https://github.com/madvirus/ddd-start
기본정보
ISBN | 9788993827446 |
---|---|
발행(출시)일자 | 2016년 05월 27일 |
쪽수 | 336쪽 |
크기 |
173 * 230
mm
/ 588 g
|
총권수 | 1권 |
Klover 리뷰 (9)
구매 후 리뷰 작성 시, e교환권 200원 적립
문장수집 (1)
e교환권은 적립 일로부터 180일 동안 사용 가능합니다. 리워드는 작성 후 다음 날 제공되며, 발송 전 작성 시 발송 완료 후 익일 제공됩니다.
리워드는 한 상품에 최초 1회만 제공됩니다.
주문취소/반품/절판/품절 시 리워드 대상에서 제외됩니다.
판매가 5,000원 미만 상품의 경우 리워드 지급 대상에서 제외됩니다. (2024년 9월 30일부터 적용)
구매 후 리뷰 작성 시, e교환권 100원 적립
-
반품/교환방법
* 오픈마켓, 해외배송 주문, 기프트 주문시 [1:1 상담>반품/교환/환불] 또는 고객센터 (1544-1900) -
반품/교환가능 기간
상품의 결함 및 계약내용과 다를 경우 문제점 발견 후 30일 이내 -
반품/교환비용
-
반품/교환 불가 사유
(단지 확인을 위한 포장 훼손은 제외)
2) 소비자의 사용, 포장 개봉에 의해 상품 등의 가치가 현저히 감소한 경우
예) 화장품, 식품, 가전제품(악세서리 포함) 등
3) 복제가 가능한 상품 등의 포장을 훼손한 경우
예) 음반/DVD/비디오, 소프트웨어, 만화책, 잡지, 영상 화보집
4) 소비자의 요청에 따라 개별적으로 주문 제작되는 상품의 경우 ((1)해외주문도서)
5) 디지털 컨텐츠인 ebook, 오디오북 등을 1회이상 ‘다운로드’를 받았거나 '바로보기'로 열람한 경우
6) 시간의 경과에 의해 재판매가 곤란한 정도로 가치가 현저히 감소한 경우
7) 전자상거래 등에서의 소비자보호에 관한 법률이 정하는 소비자 청약철회 제한 내용에 해당되는 경우
8) 세트상품 일부만 반품 불가 (필요시 세트상품 반품 후 낱권 재구매)
9) 기타 반품 불가 품목 - 잡지, 테이프, 대학입시자료, 사진집, 방통대 교재, 교과서, 만화, 미디어전품목, 악보집, 정부간행물, 지도, 각종 수험서, 적성검사자료, 성경, 사전, 법령집, 지류, 필기구류, 시즌상품, 개봉한 상품 등 -
상품 품절
-
소비자 피해보상 환불 지연에 따른 배상
2) 대금 환불 및 환불지연에 따른 배상금 지급 조건, 절차 등은 전자상거래 등에서의 소비자 보호에 관한 법률에 따라 처리함
상품 설명에 반품/교환 관련한 안내가 있는 경우 그 내용을 우선으로 합니다. (업체 사정에 따라 달라질 수 있습니다.)
기분 좋은 발견
이 분야의 베스트
이 분야의 신간
-
그림으로 배우는 도커10% 29,700 원
-
클래식 디자인의 모음집10% 89,100 원
-
린 프로덕트 플레이북10% 25,200 원
-
트랜스폼드10% 22,500 원
-
GitOps Cookbook10% 22,500 원