인프런 커뮤니티 질문&답변

살아남자님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

OSIV와 성능 최적화

어플리케이션 서비스, 도메인 서비스

해결된 질문

20.02.19 00:21 작성

·

544

4

안녕하세요! 강의 막바지에 어플리케이션 서비스, 도메인 서비스 이렇게 계층을 한 단계 더 나누는 경우가 있다고 말씀해주신거에 대한 질문이 있습니다.

1. 위와 같은 구조는 [컨트롤러, 어플리케이션 서비스, 도메인 서비스, 도메인, 리파지토리] 이렇게 구성되는건가요?

2. 위와 같이 구성 시 장점이 어떤 것이 있는 것인가요?

3. 위와 같은 프로젝트 구조말고 다른 구조는 어떤 것들이 있을까요? 검색어정도만 알려주실 수 있다면 구글링해서 찾아보겠습니다.

질문이 조금 많네요. 감사합니다.

답변 1

22

김영한님의 프로필 이미지
김영한
지식공유자

2020. 02. 19. 23:02

안녕하세요. 살아남자님^^ 좋은 질문입니다.

제가 정말 큰 시스템을 설계할 때 선호하는 방식입니다.

큰 프로젝트를 만들면 필연적으로 다음과 같이 멀티모듈로 프로젝트를 구성하게 됩니다.

api

admin

batch

domain

이런 식으로 여러 프로젝트로 나누어집니다.

여기서

api(api용 컨트롤러, api용 애플리케이션 서비스)

admin(admin용 컨트롤러, admin용 애플리케이션 서비스)

batch(batch용 애플리케이션 서비스)

domain(핵심 도메인 서비스, 핵심 엔티티, 핵심 도메인 리포지토리)

이런 식으로 나누어서 구성하게 됩니다.

핵심 비즈니스는 도메인 모듈로 모으고, api, admin, batch 등은 각각 자신의 역할을 담당하는 컨트롤러와 애플리케이션 서비스를 가지는 구조가 되는 것이지요.

그리고 각 애플리케이션 서비스는 핵심 도메인 서비스를 의존하고 사용합니다.

여기에서 이제 일부 변형을 하는 식으로 프로젝트를 진행합니다.

이 구조의 장점은 핵심 도메인 서비스와 핵심 엔티티를 깔끔하게 운영할 수 있다는 장점이 있습니다. 외부 API에 의존하거나 하는 복잡한 부분은 모두 애플리케이션 서비스 계층에서 처리해버리는 것이지요.

다음에 언젠가 기회가 되면 애플리케이션 아키텍처로 한번 강의를 고민해보겠습니다^^!

감사합니다.