서비스계층에서 의존성에 대해 질문입니다.
안녕하세요 항상 정말 강의 잘듣고 있고 평소에 쓰면서 고민했던 부분을 설명해주시고 그리고 질문으로 답해주셔서 정말 도움이 많이 되고 있습니다.
orderService에서 orderRepository,memberRepository,itemRepository 처럼 서비스 계층에서 의존성으로 다른 레파지토리를 가지는게 나은건지 아님 서비스로(orderService,,) 가져가는게 나은건지 고민이 됩니다.혹시 실무에서 보통 서비스와 레파지토리 둘중 선택하는 기준이나 각각의 장단점이 있을까요?
답변 3
10
안녕하세요. asdkfur님 좋은 질문입니다^^
이런 부분은 딱 정해진 정답이 없고, 상황에 맞는 더 나은 대안이 있을 뿐입니다.
프로젝트의 규모나, 상황등에 따라서 지금 우리 상황에 맞는 방법을 찾아가는 것이 경험 많은 시니어 아키텍트가 해야할 일이지요.
실무에서 서비스 계층이라는 것이 하나의 리포지토리만 사용하는 경우는 드뭅니다.
OrderService라고 하더라도, 연관된 수많은 테이블을 업데이트 해야 하지요.
그런 관점에서 OrderService가 다른 리포지토리에 접근한다고 해도 문제가 될 것은 없다 생각합니다.
그런데, 프로젝트가 매우 커지고, 참여하는 인원도 많고, 프로젝트 모듈도 늘어나면 이제부터는 관리가 필요합니다.
이런 상황에 Member를 완전히 별도의 패키지나 모듈(멀티모듈)로 분리하겠다고 결정하고, 앞으로 Member는 MemberService를 통해서만 접근하세요. 라고 결정하는게 시스템 복잡성을 줄이기 위해, 아키텍처상 더 나은 결정이 될 수 있습니다.
이후에 프로젝트가 더 커져서 회원을 별도의 서비스로 분리할 수도 있겠지요. 이렇게 되면 이때는 API나 이벤트를 통해서 호출하는 방식으로 진화합니다(MSA가 되는 것이지요)
제가 꼭 말씀드리고 싶은 것은, 아키텍처는 실용적인 관점에서 접근하되, 규모가 성장함에 따라서 아키텍처도 진화해야 한다는 것입니다^^
감사합니다.
1
이런 애매한 질문에도 정성스럽게 답변해주셔서 감사합니다. 항상 이러한 제 경험안에서는 보이지않는 부분에 답답함과 찜찜함을 가지고 있었는데 명쾌해 진거 같아 정말 감사합니다.
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
27
1
sdk 설정 오류
0
64
2
오탈자 - @Transactional
0
62
1
src/test/resources 테스트 경로 문제
0
55
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
70
1
MemberRepositoryTest 실행오류
0
86
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
195
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
152
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
56
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
79
1
기본 생성자
0
66
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
106
1
멤버서비스테스트 부분에서 막힙니다.
0
173
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
123
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
128
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
120
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
63
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
81
2
Repository에서 EntityManager 주입 방식 차이
0
97
1
롬복과 사용자 정의 setter 메서드
0
77
1
주문 목록 조회 fetch join 질문드립니다
0
90
1
dirty checking 질문드립니다.
0
86
1





