- Mastering Node.js(Second Edition)
- Sandro Pasquali Kevin Faaborg
- 405字
- 2021-07-02 19:28:42
Event loop ordering, phases, and priorities
The event loop proceeds through phases, and each phase has a queue of events to process. From the Node documentation:

The phases relevant to developers are the following:
- Timers: Callbacks deferred to some time in the future specified in milliseconds, such as setTimeout and setInterval
- I/O callbacks: Prepared callbacks returned to the main thread after being delegated to Node's managed thread pool, such as filesystem calls and network listeners
- Poll/check: Mainly the functions slotted on the stack according to the rules of setImmediate and nextTick
When data becomes available on a socket or other stream interface, we cannot simply execute our callback immediately. JavaScript is single-threaded, so results must be synchronized. We can't suddenly change the state in the middle of an event loop tick — this would create some of the classic multithreaded application problems of race conditions, memory access conflicts, and so on.
To learn more about how Node is bound to libuv and other core libraries, parse through the fs module code at: https://github.com/nodejs/node/blob/master/lib/fs.js. Compare the fs.read and the fs.readSync methods to observe the difference between how synchronous and asynchronous actions are implemented; note the wrapper callback that is passed to the native binding.read method in fs.read. To take an even deeper pe into the very heart of Node's design, including the queue implementation, read through the Node source at: https://github.com/joyent/node/tree/master/src. Follow FSEventWrap within fs_event_wrap.cc. Investigate the req_wrap class, a wrapper for the V8 engine, deployed in node_file.cc and elsewhere and defined in req_wrap.h.
Upon entering an event loop, Node, in effect, makes a copy of the current instruction queue (also known as stack), empties the original queue, and executes its copy. The processing of this instruction queue is referred to as a tick. If libuv, asynchronously, receives results while the chain of instructions copied at the start of this tick are being processed on the single main thread (V8), these results (wrapped as callbacks) are queued. Once the current queue is emptied and its last instruction has completed, the queue is again checked for instructions to execute on the next tick. This pattern of checking and executing the queue will repeat (loop) until the queue is emptied, and no further data events are expected, at which point the Node process exits.
Next, let's look at the event interfaces of Node.
- Cisco OSPF命令與配置手冊
- 物聯網網絡安全及應用
- Oracle SOA Suite 11g Performance Tuning Cookbook
- WordPress Web Application Development
- The Kubernetes Workshop
- 5G+區塊鏈
- 人人都該都懂的互聯網思維
- Microsoft Power Platform Enterprise Architecture
- Hands-On Docker for Microservices with Python
- 智慧的物聯網:感知中國和世界的技術
- 路由與交換技術
- 物聯網商業設計與案例
- 現場總線與工業以太網及其應用技術(第2版)
- XSS跨站腳本攻擊剖析與防御
- 互聯網心理學:新心理與行為研究的興起