동시성 처리 관련 스레드 풀 설정 질문
319
작성한 질문수 8
@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개의 작업이 실행되고, 실행이 완료된 스레드는 새로운 작업을 수행하는 방식입니다.
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





