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

이화평님의 프로필 이미지

작성한 질문수

스프링 DB 2편 - 데이터 접근 활용 기술

스프링 트랜잭션 전파7 - REQUIRES_NEW

커넥션 획득시 데드락이 걸리는 상황도 발생할 수 있을까요?

22.06.03 00:01 작성

·

507

3

안녕하세요. 영한님 질문드립니다. (감사합니다)

커넥션 데드락이 걸리는 상황도 발생할 수 있을까요? 강의에서 설명해주신 것 처럼 내부 트랜잭션이 REQURIED_NEW를 선언한 경우에 외부 트랜잭션을 수행하기 위해서 필요한 커넥션은 2개가 되는데요.

만약, 커넥션 풀에 사용가능한 커넥션이 딱 2개가 있다고 가정했을 때 thread-A와 thread-B가 외부 트랜잭션을 위해 각각 커넥션을 하나씩 획득한 상태라면 두 쓰레드 모두 내부 트랜잭션을 얻기 위해서 데드락이 발생할 수 있을 것 같다는 생각이 들었습니다. 물론, 커넥션 타임아웃 설정때문에 예외가 발생하여 각 스레드가 계속해서 blocking된 상태로 유지되진 않겠지만요..

답변 2

1

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

2022. 06. 03. 17:36

안녕하세요. 이화평님

네 가능성이 있어 보이네요.

하지만 말씀하신 것 처럼 커넥션 타임아웃이 있으니 자연스럽게 해결될 것으로 보입니다.

감사합니다.

0

김승현님의 프로필 이미지

2023. 08. 01. 18:37

말씀하신 데드락 문제는 --> 해당 식사하는 철학자 문제에서부터 이론적으로 많은 솔루션이 나왔습니다.
https://namu.wiki/w/%EC%8B%9D%EC%82%AC%ED%95%98%EB%8A%94%20%EC%B2%A0%ED%95%99%EC%9E%90%20%EB%AC%B8%EC%A0%9C#:~:text=%EC%9A%B4%EC%98%81%EC%B2%B4%EC%A0%9C%EC%9D%98%20%EA%B5%90%EC%B0%A9(%EB%8D%B0%EB%93%9C%EB%9D%BD)%EC%83%81%ED%83%9C,%EC%A7%81%EA%B4%80%EC%A0%81%EC%9C%BC%EB%A1%9C%20%EC%95%8C%20%EC%88%98%20%EC%9E%88%EB%8B%A4.

아마 커넥션 풀 내부적으로 자바 synchronised 문 (모니터) 를 사용해 mutual exclusion을 이용해 해당 데드락을 막을 것으로 생각됩니다.