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

모코코님의 프로필 이미지

작성한 질문수

동시성 처리 관련 스레드 풀 설정 질문

작성

·

223

1

@Test
@DisplayName("쿠폰 여러 명 발급")
void 쿠폰_여러_명_발급() throws InterruptedException {
    int threadCount = 1000;
    ExecutorService executorService = Executors.newFixedThreadPool(32);
    CountDownLatch latch = new CountDownLatch(threadCount);

    for (int i = 0; i < threadCount; i++) {
        final int threadNumber = i + 1;
        Integer key = i;
        executorService.submit(() -> {
            try {
                couponService.issueCoupon(param, usersMap.get(key));
            } catch (PessimisticLockingFailureException e) {
   ....
}

쿠폰 발급 동시성 처리 관련해서 테스트 코드 작성 간 궁금한 점이 있어서 질문을 올립니다.

 

구글링해서 작성해봤는데, 제가 이해하는 게 맞나 싶어서요...

 

Executors.newFixedThreadPool(32)

 

이렇게 설정해주면, 32 개의 고정된 스레드 풀을 생성한다는 것이고

 

1,000 명의 유저가 해당 스레드 풀이 나눠서 작업이 수행된다는 것인가요 ?

 

그러니까 하나의 스레드에서 약 31명의 유저를 담당한다는 뜻일까요 ?

 

아니면 순차적으로 1,000 명의 유저를 하나의 스레드에 한 명씩 배치하여 작업하는 것이고,

 

실질적으로 한 순간에 32명의 유저만 작업한다는 뜻일까요 ? ㅠㅠㅠ

답변 1

2

안녕하세요, 인프런 AI 인턴입니다.

Executors.newFixedThreadPool(32)를 사용하여 설정해주면, 말씀하신 것처럼 32개의 스레드 풀을 생성합니다. 이것은 동시에 최대 32개의 스레드가 작업을 수행할 수 있다는 의미입니다. 따라서 1,000 명의 유저 작업이 이 스레드 풀에 제출되면, 한 번에 최대 32개의 작업이 병렬로 실행될 수 있습니다. 나머지 작업들은 스레드 풀의 작업 큐에서 대기 상태로 있게 됩니다. 그리고 실행 중인 스레드가 작업을 완료하면, 대기 중인 작업 중 하나가 새로 실행되는 방식입니다.

즉, 한 순간에 작업을 수행할 수 있는 유저는 최대 32명이며, 각 스레드는 순차적으로 1,000명의 유저 작업을 처리하지만 동시에 처리되는 작업 수는 고정 스레드 풀 크기(여기서는 32개)에 의해 결정됩니다.

모코코님의 이해가 맞으시며, 마지막 설명이 실제 작업 처리 방식과 일치합니다. 한 스레드에서 31명의 유저를 담당한다기보다는, 동시에 최대 32개의 작업이 실행되고, 실행이 완료된 스레드는 새로운 작업을 수행하는 방식입니다.

모코코님의 프로필 이미지
모코코
질문자

혹시 그러면 해당 스레드풀의 크기를 정하는 기준이 있을까요 ?
서비스 규모와 요구사항에 따라 판단 기준은 갈리겠지만, 보통 몇 개의 스레드풀이 운영되는지 궁금합니다.