In Node.js we a lot talk about the event loop, so I want to know which event loop we are talking about, the Javascript event loop or the libuv event loop ? I guess libuv event loop that provides abstraction for multiple operating system of multiplexing i/o ? Am I right? If not so please explain how this stuff works? I need some internal knowledge, I know what an event loop is, I just want to know how it is connected?
-
In what context? What difference would it make if it was one or the other?Bergi– Bergi2016-07-25 16:02:05 +00:00Commented Jul 25, 2016 at 16:02
-
What do you mean by "the JavaScript event loop"? The one we have in the browser?jjm– jjm2016-07-25 16:04:20 +00:00Commented Jul 25, 2016 at 16:04
-
yes, that js event loop :) @jjmVikram Chhipa– Vikram Chhipa2016-07-25 16:06:15 +00:00Commented Jul 25, 2016 at 16:06
-
1Each different browser implement the event loop in their own way. Node.js just happen to use libuv to implement the javascript event loop. In essence, we're ALWAYS talking about the javascript event loop. How it's implemented is only relevant to people who write extensions in C/C++.slebetman– slebetman2016-07-25 17:30:15 +00:00Commented Jul 25, 2016 at 17:30
-
@slebetman you mean, node.js replace v8 event loop with libuv's ? sorry i could not understand :(Vikram Chhipa– Vikram Chhipa2016-07-26 03:46:16 +00:00Commented Jul 26, 2016 at 3:46
2 Answers
Currently Node uses the the event loop provided by libuv - namely its default event loop: uv_default_loop(). See: An Introduction to libuv by Nikhil Marathe:
A default loop is provided by libuv and can be accessed using uv_default_loop(). You should use this loop if you only want a single loop.
Note: node.js uses the default loop as its main loop. If you are writing bindings you should be aware of this.
There is a linuv architecture diagram on the Design overview page in the libuv API documentation:
In the past, libev's event loop was used in Node. See Understanding the node.js event loop by Mikito Takada:
Internally, node.js relies on libev to provide the event loop, which is supplemented by libeio which uses pooled threads to provide asynchronous I/O. To learn even more, have a look at the libev documentation.
Some good resources on the Node event loop:
- Understanding the node.js event loop by Mikito Takada
- Understanding node.js by Felix Geisendörfer
- Understanding the Node.js Event Loop by Trevor Norris
- Node.js itself is blocking, only its I/O is non-blocking by Jeremy Epstein
- An Introduction to libuv by Nikhil Marathe
- The libuv API documentation
Thanks to Saúl Ibarra Corretgé for the clarification in the comments.
6 Comments
uv_default_loop might also change in the future, with the introduction of multiple isolates, but it holds true at the moment. Thanks for updating the answer!There is not just 1 event loop but different implementations of the event loop depending on the context. For example Chrome browser uses the event loop of the V8 JS engine. NodeJS uses the V8 engine but not it's event loop - it uses the Libuv event loop instead.
I made a video with a detailed explanation recently here: https://www.youtube.com/watch?v=4xsvn6VUTwQ
