Is NodeJS really Single-Threaded?

2019-01-03 13:28发布

Node.js solves "One Thread per Connection Problem" by putting the event-based model at its core, using an event loop instead of threads. All the expensive I/O operations are always executed asynchronously with a callback that gets executed when the initiated operation completes.

The Observation IF any Operation occures is handled by multiplexing mechanisms like epoll().

My Question is now:

  • Why doesnt NodeJS Block while using the blocking Systemcalls select/epoll/kqueue?

  • Or isnt NodeJS Single Threaded at all, so that a second Thread is
    necessary to observe all the I/O-Operations with select/epoll/kqueue?

3条回答
冷血范
2楼-- · 2019-01-03 13:40

No.

When I/O operations are initiated they are delegated to libuv, which manages the request using its own (multi-threaded, asynchronous) environment. libuv announces the completion of I/O operations, allowing any callbacks waiting on this event to be re-introduced to the main V8 thread for execution.

V8 -> Delegate I/O (libuv) -> Thread pool -> Multi threaded async

查看更多
【Aperson】
3楼-- · 2019-01-03 13:50

NodeJS is evented (2nd line from the website), not single-threaded. It internally handles threading needed to do select/epoll/kqueue handling without the user explicitly having to manage that, but that doesn't mean there is no thread usage within it.

查看更多
Explosion°爆炸
4楼-- · 2019-01-03 14:05

JavaScript is single threaded, so is event-model. But Node stack is not single-threaded.

Node utilizes V8 engine for concurrency.

查看更多
登录 后发表回答