작성
·
40
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
그 트랜잭션 전파에 대해서 공부하다가 궁금증이 생겼는데
JpaRepository의 구현체인 SimpleJpaRepository에서 saveAll() 메서드도 내부에서 save()메서드를 호출하잖아요?
그러면 이때 호출되는 save()메서드도 내부호출이니까 @Transactional이 적용이 안되는 건가요?
풀어서 말하자면
saveAll()이 호출될때 @Transactional로 트랜잭션이 시작됨
saveAll() 내부에서 save() 메서드를 호출하지만 내부호출이므로 트랜잭션 전파가 아닌 그냥 save()메서드가 호출됨
결과적으로는 트랜잭션이 saveAll() 호출시 하나만 시작되고 save()들은 내부호출이므로 트랜잭션 전파를 받는것이아닌 saveAll()이 호출될때 시작된 트랜잭션을 따름
위와 같이 이해하는게 맞을까요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 김민재님.
spring의 트랜잭션 AOP에서 내부호출에 대한 부분은 많은 분들이 이해하는 데 혼란을 겪을 수 있는 주제입니다. 말씀하신 상황에 대해 설명드리겠습니다.
saveAll()의 트랜잭션 시작: @Transactional
이 메서드에 적용되면, 스프링은 AOP 프록시를 사용하여 메서드 호출 이전에 트랜잭션을 시작합니다. saveAll()
이 메서드 시작 시에 트랜잭션을 시작하게 됩니다.
내부에서 save() 호출: saveAll()
메서드 내부에서 save()
메서드를 호출하지만, 이는 같은 클래스 내의 호출입니다. 여기서 @Transactional
의 트랜잭션 전파가 ‘없다는’ 표현은 약간 오해일 수 있습니다. 실제로, 트랜잭션은 이미 시작되었으므로, 내부 호출된 메서드인 save()
는 이미 열린 트랜잭션에 참여하게 됩니다.
결과적으로 트랜잭션 흐름: saveAll()
에서 트랜잭션을 시작하면, 이후 save()
호출은 이 트랜잭션 컨텍스트 내에서 수행됩니다. 즉, 이미 열린 트랜잭션을 계속 따르게 됩니다.
말씀하신 이해는 대체로 올바릅니다. saveAll()
에서의 트랜잭션은 save()
내부 호출에서 분리되지 않고 이미 시작한 트랜잭션을 그대로 따르게 됩니다. 스프링에서는 이미 생성된 트랜잭션 내에서 트랜잭션 전파를 처리하므로, 내부의 save()
는 트랜잭션 전파의 형태로 동작한다고 볼 수 있습니다.
혹시 트랜잭션 전파에 대한 좀 더 깊이 있는 이해가 필요하시다면, 아래 링크도 참고하시길 바랍니다:
- 트랜잭션 전파 - 기본 이해
- 프록시와 내부 메서드 호출 관련 이해
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.