Inflearn Community Q&A
findById 동시성 테스트 실패
Resolved
Written on
·
463
·
Edited
0
MemberRepository는 jpaRepository인 상태이고,
findById관련해서 동시성 테스트를 하고 있는데, 해당 테스트가 통과를 하지 않아 그 이유가 궁금합니다.
단순하게 여러 스레드에서 findById하는 테스트 코드인데 왜 통과를 못하는지 잘 이해가 가지 않습니다.
@SpringBootTest
@Transactional
public class Test{
@Autowired
MemberRepository memberRepository;
Member member;
@BeforeEach
void setUp() {
member = Member.builder().name("testMember").build();
memberRepository.save(member);
}
@Test
public void test() throws Exception
{
int threadCount = 10;
ExecutorService executorService = Executors.newFixedThreadPool(threadCount);
CountDownLatch latch = new CountDownLatch(threadCount);
AtomicInteger failCount = new AtomicInteger();
AtomicInteger successCount = new AtomicInteger();
for (int i = 0; i < threadCount; i++) {
executorService.submit(
() -> {
try {
memberRepository.findById(member.getId()).get();
successCount.addAndGet(1);
} catch (Exception e) {
System.out.println(e.getMessage());
failCount.addAndGet(1);
}finally {
latch.countDown();
}
}
);
}
latch.await();
assertThat(successCount.get()).isEqualTo(threadCount);
assertThat(failCount.get()).isEqualTo(0);
}
}
javaspringspring-bootjpa
Quiz
66% of people got it wrong. Give it a try!
Spring Data JPA 리포지토리의 사용자 정의 메서드를 구현하는 주된 이유는 무엇일까요?
단순한 CRUD 연산을 수행하기 위해서입니다.
Spring Data JPA만으로는 구현하기 어려운 복잡한 쿼리나 JDBC/MyBatis 사용 등 특정 기술이 필요할 때 사용합니다.
Spring Data JPA가 제공하는 기본 메서드를 오버라이드하기 위해서입니다.
모든 리포지토리 메서드를 수동으로 구현하기 위해서입니다.
Answer 1
0
dla40512238
Questioner
https://velog.io/@chullll/JPA-Transactional-%EA%B3%BC-%EB%8F%99%EC%8B%9C%EC%84%B1
트랜잭션은 싱글스레드에서 작동하기 때문에 멀티 스레드 환경에서는 처리가 필요하네용





