쓰레드 풀

jegw·2023년 8월 29일
0

TIL

목록 보기
68/77

쓰레드 풀은 프로그램 내에서 여러개의 작업을 동시에 처리할 수 있게 한다.

  • 쓰레드 풀(thread pool)은 프로그램이 동시에 여러 작업을 수행할 수 있게 하는 방법 중 하나입니다. 쓰레드 풀은 미리 생성된 쓰레드의 집합으로, 이들 쓰레드는 요청된 작업을 처리합니다.

  • 일반적으로, 각각의 클라이언트 요청에 대해 새로운 쓰레드를 생성하거나 기존의 쓰레드를 종료하는 것은 비용이 많이 들고 시간도 오래 걸립니다. 이럴 때, 쓰레드 풀을 사용하면 미리 생성해둔 여러 개의 쓰레드를 재사용하여 이런 비용과 시간을 줄일 수 있습니다.


쓰레드 풀에서는 다음과 같은 작업들이 일어납니다:

작업 요청

: 클라이언트 혹은 사용자로부터 어떤 작업 요청이 들어옵니다.

작업 할당

: 해당 작업은 큐에 추가되고, 그 후에 사용 가능한(즉, 현재 다른 작업을 처리하지 않는) 스레드가 해당 큐에서 작업을 가져와서 실행합니다.

작업 완료

: 스레드가 해당 작업을 완료하면 결과를 반환하고 다시 스레드 풀로 돌아와 다음 할당될 작업을 기다립니다.


장점

쓰레드 풀을 사용하는 주요 이유는 성능 최적화와 자원 관리에 있습니다. 다음과 같은 장점들이 있습니다:

자원의 효율적인 사용

: 쓰레드를 생성하고 소멸시키는 것은 시스템 자원을 많이 사용합니다. 쓰레드 풀에서는 이미 만들어진 스레드를 재사용함으로써 이런 오버헤드를 줄일 수 있습니다.

성능 개선

: 스레드 생성과 제거에 대한 오버헤드가 줄어들면서 응답 시간이 개선되고, 전반적인 시스템 성능이 향상됩니다.

자원의 제어

: 쓰레드 풀을 사용하면 동시에 실행 가능한 스레드의 최대 개수를 제한할 수 있습니다. 이는 메모리 부족 문제나 CPU 과부하와 같은 문제를 예방하는 데 도움이 됩니다.

작업 처리 시간의 예측 가능성

: 일정한 크기의 쓰레드 풀을 유지함으로써 작업 처리 시간을 예측하는 것이 더욱 용이해집니다.

따라서, 멀티스레딩 환경에서 여러 요청을 처리할 때, 고정된 크기의 쓰레드 풀을 사용하여 요청에 대응하는 것은 매우 일반적입니다.

0개의 댓글