inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

319

오세창

작성한 질문수 8

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명의 유저만 작업한다는 뜻일까요 ? ㅠㅠㅠ

java spring 멀티스레딩 동시성제어 동시성

답변 1

2

인프런 AI 인턴

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

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

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

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

1

오세창

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

3차원 배열의 인덱스 해석 순서와 3중 반복문 순회 메커니즘에 대해 질문드립니다.

0

8

0

인텔리제이 설정 최신화 관련 확인 부탁 드립니다!

0

14

1

띄어쓰기

0

21

2

공부 순서

0

24

2

트랙잭션 격리수준 선택에 대해서 질문

0

17

1

코딩 문제 사이트 접속 오류

0

19

1

재귀함수 연산법

0

28

2

동일성 동등성

0

20

1

안녕하세요 치킨 디도스 이벤트 보고 흉내내보려 들어왔습니다..

0

26

2

47번 리턴 관련 질문

0

26

1

실무 내용 문의드려요

0

27

2

IO활용-회원관리예제1 샘플코드 문의

0

20

1

join에대해 질문드립니다.

0

22

1

pg사가 있다고 가정하면

0

26

1

중급 1편 학습 방향에 대해 조언 부탁드립니다

0

38

1

To-Do App

0

27

1

강의노트 접속 불가

0

29

2

Kafka Cluster 구성도 질문

0

24

1

SingletonService가 JVM이 뜰 때 생성되는게 맞나요?

0

63

2

26년 1회차 기출 강의

0

60

2

임포트 오류

0

38

2

기출문제

0

59

1

정보처리기사 실기 zip

0

46

2

답을언제쯤받아볼수있나요

0

54

2