동시성 이슈 - 3회 이상 재시도를 자동으로 하게 하는 방법
396
작성한 질문수 34
안녕하세요,
동시성 이슈에 대한 이야기를 해주시면서 "등록 시도를 했는데 유니크에서 튕겼다면 누군가 먼저 신규 번호를 선점했다는 뜻이니 3회 이상 재시도를 자동으로 하게 하는 방법으로 풀 수 있다"란 말씀을 해주셨습니다.
그래서 아래 예시 코드처럼 DataIntegrityViolationException 을 try-catch로 잡아서 재시도를 하라는 뜻으로 이해했습니다. (하지만 로컬에서 동시성 문제를 발생시키는 방법을 찾지 못해 맞는 코드인지 모르겠습니다.. @Transactional이 있다면 DataIntegrityViolationException 를 잡기 위해서 try-catch 블럭 내부에서 flush()를 호출하기 위해 saveAndFlush() 를 사용한다는 말도 있더라구요?)
public ExampleEntity save(ExampleEntity entity) {
for (int i = 0; i < 3; i++) {
try {
// 저장 시도
return repository.save(entity);
} catch (DataIntegrityViolationException e) {
// 유니크 제약 조건 위배 예외 처리
log.info("저장 실패");
}
}
throw new RuntimeException("저장에 실패했습니다.");
}이러한 방법이 맞다면 더 좋은 방법이 있는지, 혹시 만약 이 방법이 아니라면 어떤 방법으로 해결할 수 있는지 알려주시면 감사하겠습니다.
좋은 강의 항상 감사드립니다.
답변 1
0
안녕하세요, lch9502 님!
접근하신 방법이 맞습니다. 몇 가지 좀 더 말씀드리자면요. ㅎㅎ
테스트 코드를 통해 동시성 테스트를 할 수 있습니다. ExecutorService를 통해 스레드풀을 만들고 동시에 요청을 발생시키는 방법을 한번 찾아보셔도 좋을 것 같습니다 ㅎㅎ
위와 같은 재시도 방법의 경우, 비즈니스 플로우 상 크게 중요도가 높지 않은 케이스(즉, 3번 시도 후 실패해도 기능 상 중요하지 않거나, 사용자가 다시 요청을 하는 행위가 비용이 크지 않은 경우)에서 간단하게 시도해볼 수 있는 방법입니다. 만약 요청의 성공을 보장해야 하는 경우, 레디스 등을 활용한 분산락 같이 동시성 이슈를 해소하기 위한 여러가지 기법을 적용해볼 수 있으니 참고해 주세요.
도움이 되셨기를 바랍니다.
감사합니다. 🙂
private 상수 테스트 관련 질문
0
83
1
void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??
0
126
2
커버리지는 어떻게 활용하시는지 궁금합니다.
0
161
2
테스트 문서화 질문입니다
0
105
2
단위테스트 질문이 있습니다
0
96
2
컨트롤러는 모킹을 한 이유가 궁금합니다.
0
103
2
ERD 가장자리에 있는 도메인 테스트 질문
0
89
2
DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?
0
135
2
OrderCreateRequest DTO에 대해서 궁금한점
0
102
2
고전파의 테스트 대역 사용 대상, 공유 의존성
0
156
2
계층 관련 질문이 있습니다.
0
139
3
'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다
1
124
2
혹시 update 로직은 어떻게 테스트하나요? (@Setter?)
0
134
2
단위테스트와 통합테스트의 경계가 궁금합니다.
0
228
2
Service+Repository 통합테스트 관련 질문입니다.
0
150
2
OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요
0
184
2
test 용 .yml
0
90
2
throws Exception
0
80
2
카페키오스크 클래스 문의 ,,
0
89
2
Rest docs 문서용 테스트코드를 따로 작성해야 되나요?
0
173
2
테스트 코드에서 필요한 생성자
0
138
1
tearDown 순서
0
116
2
@Builder 생성자 private
0
136
2
@DisplayName gradle / intellJ
0
93
2





