inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

트랜잭션 동시성 이슈 관련 질문 드립니다.

410

gone9227

작성한 질문수 2

0

안녕하세요 영한님!

스프링 관련 강의들 잘 듣고 있습니다. 항상 좋은 강의 감사합니다.

질문은 Transaction 과 lock 에 관련된 것인데요. 

현재 멀티쓰레드로 Centercut을 돌리면서 해당 데이터에 대한 Key 를 채번하는데, 

Key를 채번하는 과정에서 동시에 호출이 발생할 때 무결성 예외가 발생하는 문제가 있었습니다.

현재 상황은 채번이 이루어지는 메소드가 호출될 때 마다 Transaction을 새로 생성하기 위해

@Transactional(propagation = Propagation.REQUIRES_NEW)

어노테이션을 붙였고,  

Repository에서 실제 Max 일련번호를 가져오기 위한 Select 쿼리에는 

 @Lock(LockModeType.PESSIMISTIC_WRITE)

다음과 같이 락 모드를 설정했습니다.

그런데 문제는 Select 했을 때 데이터가 존재하면 그 행에 대해 lock을 잡을 수 있지만 데이터가 없을 경우엔 locking 할 row가 존재하지 않아 동시성 문제가 발생하는 것 같습니다. (동시에 데이터가 없다고 인식하고 새로운 데이터 생성 후 insert 시도 => 무결성 제약조건 위배)

해결방법을 찾아 보니 메소드에 synchronized 를 붙이거나 try~catch 문으로 강제로 추가 수행하는 것 등이 나오는데 좀 더 나은 방법이 있을지 질문 드립니다. 

감사합니다!!

java spring spring-boot JPA

답변 1

0

김영한

안녕하세요. gone9227님

원하시는 방식을 트랜잭션으로 해결할 수 있을지 잘 모르겠습니다.

채번 방식을 바꾸는 것을 고민해보시면 좋겠습니다.

혹시 도움을 드릴 수 있는 분이 있으면 답변 부탁드려요.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

64

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

99

3

MemberRepository 구현체

0

54

1

pdf 표현 질문드립니다.

0

59

1

로그가 남지 않는 문제.

0

78

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

67

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

68

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

87

2

Sort 인터페이스는 잘 사용 안하나요?

0

50

1

스캔대상 질문드립니다.

0

45

1

하이버네이트6에서의 최적화에 이은 질문

0

81

1

save() vs saveAndFlush DB 통신 횟수

0

50

1

순수 JPA 리포지토리 코드 수정부분

0

85

2

bulk연산 후 flush하는 이유를 모르겠어요

0

147

3

bulk insert 질문입니다.

0

174

2

교만했던 것 같아요.

0

142

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

143

2

동적 테이블에 대한 질문

0

84

1

영속성 전이와 연관관계

0

128

2

강의 10:25 질문

0

71

1

단건 update 질문

0

94

2

엔티티 와 도메인의 경계

0

124

1

UsernameOnlyDto 타입 type mismatch 오류

0

114

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

131

1