최근 Baeldung 의 Author 들이 활발하게 활동을 하고 있습니다.
그만큼 최근에 여러가지 이슈들이 많이 있다는 것을 의미하는 것도 같습니다.
최근 Jdk 의 앞으로의 방향에 대한 포스트나 유튜브를 보다가 관심이 갔던 부분 중 하나가 Virtual Threads 부분이었습니다. 특히나 Spring Framework 의 TaskExecuteor에 어떤 식으로 포함이 될 지 궁금하면서도 찾아보지는 않았네요.(게으른것도 있지만 요즘 프로그램 기초편을 다시 공부중이라 정신이 없네요)
Baeldung Team 에서 뭔가 해주지 않을까 했는데 드디어 Post가 올라왔습니다.
해당 포스트로 넘어가는 링크 보기 전에 잠시 Virtual Thread에 대해서 알아볼께요.
Java Virtual Threads (JVTs)
JVTs 는 Java 19 에서 새롭게 포함된 새로운 기능입니다. Platform Threads의 대안으로 등장했고, Platform Threads 보다 경령의 Thread로서 제안되었는데, 이 프로젝트는 Project Loom에 의해서 발전하고 있습니다.
JVTs는 자바 가상 머신 (JVM)에서 관리되는 Thread model로 특정 OS Threads 에 바인딩되어 동작하지 않기 때문에 Platform Thread 보다 훨씬 효율적이고 확장 가능하다는 설명입니다. 일단 스펙 설명만으로 보면 Threads의 생성(created)과 소멸(destroyed)이 On-demand 로 동작하기 때문에 좀 더 Scalable하다고 합니다. 이는 높은 병렬처리(High-concurrency) application 즉 대규모 threads 가 필요한 application에 적합하다고 하네요.또한 JVTs는 연속성(continuations) 및 가상스택 프레임(virtualized stack frames)과 같은 다른 기능을 포함한다고도 하는데 이 부분은 무슨 이야기인지 잘 모르겠습니다.
다만, 아직 실험(experiment) 수준으로 앞으로의 행보를 잘 따라가보면 좋을 것 같습니다. 최종적으로 어떨지는 잘 모르겠습니다만, Platform Threads 를 완전 대체하려고 나온 것은 아닌 것으로 보이고, 경량의 확장이 필요한 Threads를 사용하고자 할때의 대안으로서 개발이 진행되고 있는 것으로 보입니다.
지금까지 확인한 장점을 잠시 알아보면 다음과 같습니다.
- 효율성 : JVTs는 JVM에서 관리하는 Thread로 특정 OS Thread에 바인딩되지 않기 때문에 더 효율적
- 확장성 : 필요할때마다 생성하고 소멸시킬 수 있기 때문에 Platform Threads 보다 더 확장이 용이. 많은 쓰레드가 필요하고 병행 처리가 중요한 경우에 적합
- 간편성 : JVM이 관리하는 Thread이기 때문에 생성/소멸이 쉬워서, 개발자의 Thread 사용시의 어려움인 생성/소멸/동기화 관리 같은 걱정을 줄여줌
Project Loom 프로젝트는?
Project Loom 의 프로젝트의 Goal 설명을 보면 아래와 같습니다.
The goal of this Project is to explore and incubate Java VM features and APIs built on top of them for the implementation of lightweight user-mode threads (fibers), delimited continuations (of some form), and related features, such as explicit tail-call.간단히 보면 Project Loom은 자바 플랫폼에서 병렬성 및 확장성을 개선하기 위한 대규모 프로젝트로 자바 19에서 도입된 Java Virtual Threads (JVTs)를 비롯한 여러 가지 새로운 기능들로 구성된 프로젝트를 연구하는 프로젝트입니다.
이제 Spring 6 에서 Virtual Threads 를 사용하는 방법(아직까지 Experiment 입니다)을 Baeldung 에서 확인하세요.
댓글
댓글 쓰기