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

Kim Dan님의 프로필 이미지

작성한 질문수

sprign webflux와 main 쓰레드 수

23.10.14 11:59 작성

·

302

·

수정됨

0

제가spring webflux를 공부하다가 궁금한게 있어서 이렇게 질문 남깁니다.

webflux는 비동기 프로그래밍을 지원하기 때문에 적은 쓰레드 수로도 대량의 트래픽을 처리할 수 있다고 알고 있는데요. [실제로 사용자 요청을 받는 main 쓰레드는 한 개만 생성되는지 궁금합니다.]

webflux는 블로그를 보다가 default값으로 core 당 한개의 쓰레드가 생성한다고 본거 같은데.. 이게 main 쓰레드는 한개 인데 sub 쓰레드(block 상태 풀린 쓰레드 요청 처리 용, event loop 처리 용 등)들이 core 갯수까지 추가적으로 생성된다는건지(main + sub == core수), 아니면 main 쓰레드가 실제로 코어 수만큼 생성이 된다는 의미인지 잘 모르겠네요..

마지막으로, 후자가 맞다면 webflux는 소수의 main 쓰레드로 멀티 쓰레딩 지원과 비동기 프로그래밍을 지원한다고 보면되는걸까요?

답변 1

0

인프런 AI 인턴님의 프로필 이미지

2023. 10. 15. 12:01

안녕하세요, 인프런 AI 인턴이에요. Spring WebFlux에 대한 궁금증에 대해 답변해드릴게요.

Spring WebFlux는 비동기 프로그래밍을 지원하기 위한 모듈로, 적은 수의 스레드로도 대량의 트래픽을 처리할 수 있습니다.

실제로 사용자 요청을 받는 main 스레드에 대해서 말씀드리면, Spring WebFlux에서는 main 스레드가 한 개만 생성됩니다.

그러나, sub 스레드는 core의 개수에 따라 추가적으로 생성됩니다. core의 기본값은 보통 CPU 코어의 수와 동일한데요.

즉, main 스레드 한 개와 sub 스레드(core 수만큼)의 조합으로 비동기 처리 및 블로킹 작업 처리 등이 이루어지게 됩니다.

따라서 Spring WebFlux는 소수의 main 스레드로 멀티 스레딩과 비동기 프로그래밍을 지원한다고 볼 수 있습니다.

더 궁금하신 내용이 있으시면 언제든지 물어보세요. 좋은 하루 되세요.

Kim Dan님의 프로필 이미지

작성한 질문수

질문하기