본문 바로가기

Books32

Chapter10. 이벤트 외부 서비스가 정상이 아닐 경우, 트랜잭션 처리를 어떻게 해야할까 ? 비동기 이벤트를 사용해서 두 시스템 간의 결합도를 낮춘다. ( 강결합 → 약결합 ) 이벤트가 발생한다 → 상태가 변경됐다 → 해당 이벤트에 반응하여 원하는 동작을 수행하는 기능 작성 이벤트 클래스 : 이벤트를 표현 디스패처 : 스프링이 제공하는 ApplicationEventPublisher 를 이용 Events: 이벤트를 발행, 이벤트 발행을 위해 ApplicationEventPublisher 를 사용 이벤트 핸들러 : 생성 주체가 발생한 이벤트를 전달받아 이벤트에 담긴 데이터를 이용해서 원하는 기능을 실행 ex) ‘주문 취소’ 이벤트를 받는 이벤트 핸들러는 해당 주문의 주문자에게 SMS로 주문 취소 사실을 알린다. 이벤트 디스패처 :.. 2024. 4. 17.
Chapter7~8. 도메인서비스 ~ 애그리거트 트랜잭션 관리 여러 애그리거트가 필요한 기능 ex) 결제 금액 계산 로직 → 상품, 주문, 할인, 회원 애그리거트 등 필요. 하나의 애그리거트에 넣기 애매한 도메인 기능을 억지로 넣어 구현하면 안된다. 도메인 기능을 별도 서비스로 구현하는 방법을 사용한다. 도메인 서비스는 도메인 로직을 표현하므로 도메인 서비스의 위치는 다른 도메인 구성요소와 동일한 패키지에 위치 @Service @Transactional public class PaymentCalculationService { private final ProductRepository productRepository; private final DiscountRepository discountRepository; private final MemberRepository m.. 2024. 4. 10.
Chapter6. 응용 서비스와 표현 영역 사용자에게 기능을 제공하려면 도메인과 사용자를 연결해 줄 표현 영역과 응용 영역이 필요. 응용 서비스 애플리케이션의 사용 사례(Use Case)를 구현하는 역할 주로 사용자의 요청을 처리하고, 도메인 객체 간의 상호 작용을 조정하여 트랜잭션 경계를 설정 응용 서비스는 도메인 로직을 직접적으로 구현하지 않고, 도메인 계층의 서비스와 리포지토리를 사용하여 해당 기능을 수행 // 도메인 로직을 직접 구현하지 않는다 @Service public class OrderService { @Autowired private OrderRepository orderRepository; @Autowired private ProductService productService; @Transactional // 트랜잭션 경계 설정.. 2024. 4. 8.
Chapter5. 스프링 데이터 JPA를 이용한 조회 기능 CQRS : 명령 모델과 조회 모델을 분리하는 패턴 명령 모델 : 상태를 변경하는 기능 구현 ex) 회원 가입, 주문 취소 조회 모델 : 데이터를 보여주는 기능 ex) 주문 목록, 주문 상세, 회원 상태 스프링 데이터 JPA 간단 예제 // Entity 클래스 생성 @Entity @Getter public class Book { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String title; private String author; } // Repository 인터페이스 생성 public interface BookRepository extends JpaRepository { } // Service 클.. 2024. 4. 8.
Chapter4. 리포지터리와 모델 구현 모듈 위치 // 인터페이스는 도메인 하위에 위치 domain/ └── repository/ └── UserRepository.java // 구현체는 인프라스트럭처 하위에 위치 infrastructure/ ├── repository/ └── JpaUserRepository.java JPA 를 사용하면 수정한 결과를 반영하는 메서드를 따로 추가하지 않아도 자동으로 DB 에 반영한다 ( 변경 감지 ) 스프링 데이터 JPA 예제 @Entity public class User { @Id @GeneratedValue private Long id; private String name; private int age; } public interface UserRepository extends JpaRepository {.. 2024. 4. 8.
Chapter3. 애그리거트 애그리거트 : 복잡한 도메인을 이해하고 관리하기 쉬운 단위로 만드려면 상위 수준에서 모델을 조망할 수 있는 방법 애그리거트는 도메인 주도 설계(DDD)에서 사용되는 중요한 개념 애그리거트는 함께 변경되는 일관성 있는 엔터티들의 집합 애그리거트 내 엔터티들은 서로 밀접하게 연관되어 있으며, 외부 엔터티는 애그리거트 루트를 통해서만 애그리거트 내 엔터티에 접근 가능 애그리거트 루트 : 애그리거트를 식별하고 외부 엔터티와 상호 작용하는 엔터티 모든 객체가 일관된 상태를 유지하려면 애그리거트 전체를 관리할 주체가 애그리거트 루트의 역할 식별: 애그리거트를 식별하는 고유한 ID를 가진다. 접근 제어: 외부 엔터티가 애그리거트 내 엔터티에 접근하도록 허용하는 역할을 한다. 변경 관리: 애그리거트 내 엔터티의 변경을.. 2024. 4. 7.
Chapter2. 아키텍처 개요 상위 계층에서 하위 계층으로의 의존만 존재하고 하위 계층은 상위 계층에 의존하지 않는다. 1. 표현 영역 (Presentation Layer) 사용자 인터페이스(UI)를 담당 사용자와 직접 상호 작용하며, 시각적 요소와 기능을 제공 예시: JSP, Thymeleaf, React, Vue.js 등 2. 응용 영역 (Application Layer) 비즈니스 규칙을 구현 도메인 모델과 상호 작용하여 사용자 요청을 처리 예시: 서비스 클래스, 유틸리티 클래스 등 @Transactional public void cancel(OrderNo orderNo, Canceller canceller) { Order order = orderRepository.findById(orderNo) .orElseThrow(() ->.. 2024. 4. 5.
Chapter1. 도메인 모델 시작하기 도메인 : 소프트웨어로 해결하고자 하는 문제 영역 도메인은 여러 하위 도메인으로 구성된다. 소프트웨어가 도메인의 모든 기능을 제공하지는 않는다. 도메인 모델 : 특정 도메인을 개념적으로 표현한 것 기본적으로 도메인 자체를 이해하기 위한 개념 모델 도메인 모델 패턴 사용자 인터페이스 또는 표현 사용자의 요청을 처리하고 사용자에게 정보를 보여준다. 외부 시스템일 수도 있다. 응용 사용자가 요청한 기능을 실행 도메인 시스템이 제공할 도메인 규칙을 구현 인프라스트럭처 DB 나 메시징 시스템과 같은 외부 시스템과의 연동 처리 도메인 모델 도출 모델을 구성하는 핵심 구성요소, 규칙, 기능을 찾는 것 요구사항 확인하기 엔티티와 밸류 엔티티 엔티티 객체마다 고유해서 각 엔티티는 서로 다른 식별자를 갖는다. 특정 규칙에.. 2024. 4. 5.
3장. 모든 객체의 공통 메서드 아이템10. equals는 일반 규약을 지켜 재정의하라. 언제 사용할까 ? 논리적 동치성을 확인해야 할 때 값 클래스(String, Integer 등) 등 객체가 같은지가 아니라 값이 같은지 알고 싶을 때 다음 상황 중 하나에 해당하면 재정의 하지 않는 것이 최선. 각 인스턴스가 본질적으로 고유하다. 인스턴스의 ‘논리적 동치성’ 을 검사할 일이 없다. 상위 클래스에서 재정의한 equals 가 하위 클래스에도 딱 들어맞는다. 클래스가 private 이거나 package-private 이고 equals 메서드를 호출할 일이 없다. 오버라이딩 시 고려 사항: 비교 대상 필드 모두 비교 null 체크 반사성(reflexivity): 자신과 자신을 비교했을 때 true 반환 대칭성(symmetry): a.equa.. 2024. 4. 3.