순수한 서비스 계층에 대한 의문???
82
9 asked
서비스 계층을 순수한 비즈니스 로직만 남도록 하고,
특정 기술에 의존하지 않도록 하는 과정을 배우면서
많은 영감을 얻었습니다!
그런데, @Transactional은 과연 순수한가 하는 의구심이 듭니다.
내부 코드에서는 깔끔하게 지웠지만,
순수한 자바 환경에서는 여전히 특정 예외상황에서 불완전하게 동작하고,
어노테이션을 통해 프록시 기술에 의존하게 되는데요.
테스트 시에도 순수한 자바테스트가 아니라 스프링 컨테이너에서 관리되도록 해야하니 순수하지 않다고 느껴집니다.
이런건 트랜잭션을 순수한 자바코드만으로 깔끔하게 구현하기 어렵기때문에 현실적으로 타협한건가요?
여전히 찝찝한 마음이 남아있습니다 ㅠㅠ
Answer 2
0
안녕하세요, 인프런 AI 인턴입니다. 정신차려님께서 질문하신 서비스 계층의 순수성 및 @Transactional 어노테이션 사용에 대한 의구심에 대해 답변드리겠습니다.
@Transactional 어노테이션은 스프링 프레임워크에서 제공하는 트랜잭션 관리 기능을 간편하게 사용하게 해주지만, 말씀하신 것처럼 이는 스프링이 제공하는 기술적 이점을 활용하는 것이기에, 순수한 자바 환경과는 차이가 있을 수 있습니다. 결과적으로, 이는 트랜잭션 관리 측면에서 스프링의 프록시 기반 메커니즘에 의존하게 됩니다. 이런 점에서 순수한 자바 환경이라고 보기 어려운 것이 사실입니다.
포기하지 않고 순수한 자바 기반으로 트랜잭션을 구현하는 것은 복잡성과 Error Handling 때문에 일반적으로 권장되지 않습니다. 스프링의 @Transactional을 사용하는 것은 이러한 현실적 제약 조건 내에서 최적의 선택이라 할 수 있습니다. 스프링의 트랜잭션 관리는 다양한 데이터베이스와의 일관성을 관리하고, 다양한 예외 상황을 처리하는데 큰 힘이 됩니다.
관련하여 비슷한 주제를 다루고 있는 질문 및 답변을 참고하시면 도움이 될 것 같습니다:
- 스프링 jpa 기반의 Entity가 올라온다면 서비스 계층이 순수하다고 볼 수 있을까요?
- Spring을 공부하면서 애플리케이션 영역에서 트랜잭션을 적용을 권고하는 사유가 있을지 궁금합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
27
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
49
1
jdbc 학습하다 궁금해서 질문드려요
0
80
1
정상이체와 이체중 예외발생 차이
0
68
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
86
1
3_4test, 4test 자동 리소스 안됨
0
58
2
데이터베이스 선택 관련 질문.
0
68
2
after 메서드 사용 유무
0
56
2
데이터베이스 접근 및 DB 락
0
52
1
@SpingBootTest, @TestConfiguration
0
55
1
Read Committed 격리 수준 사용 관련 질문
0
48
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
66
2
커리큘럼 관련 질문
0
76
1
서비서 계층 스프링 프레임워크 사용
0
87
1
validation(toMember)의 위치
0
83
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
165
2
member 상수 질문
0
120
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
153
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
108
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
94
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
95
1
강의 14분쯤 Exception 질문
0
111
2
memberId 맴버변수를 String 으로 잡은 이유
0
127
2

