Node.js 中的 异步 I/O

简介: Node.js 中的 异步 I/O

异步 I/O

异步 I/O 实现现状

  • 异步 I/O 与 非阻塞 I/O

    • 操作系统内核对于 I/O 只有两种方式:阻塞与非阻塞
    • 阻塞 I/O 造成 CPU 等待浪费,非阻塞则需要轮询去确认是否完全完成数据获取,让 CPU 处理状态判断,对 CPU 资源造成浪费
    • 现存轮询技术

      • read
      • select
      • poll
      • epoll
      • kqueue
  • 理想的非阻塞异步 I/O

    完美的异步 I/O 应该是应用程序发起非阻塞调用,无须通过遍历或者事件唤醒等方式轮询,可以直接处理下一个任务,只需在 I/O 完成后通过信号或回调将数据传递给应用程序即可。

Node 异步 I/O

  • 事件循环
  • 观察者

    • 每个事件循环中有一个或者多个观察者,而判断是否有事件要处理的过程就是向这些观察者询问是否有要处理的事件
    • 事件循环是 生产者/消费者 模型。异步 I/O、网络请求等是事件的生产者,源源不断为 Node 提供不同类型的事件,这些事件被传递到对应的观察者那里,事件循环则从观察者那里取出事件并处理。
  • 请求对象

    • JS 发起调用到内核执行完 I/O 操作的过程中,存在一种中间产物——请求对象
  • 执行回调

    • I/O 观察者回调函数的行为就是取出请求对象的 result 属性作为参数,取出 oncomplete_sym 属性作为方法,然后调用执行,以此达到调用 JavaScript 中传入的回调函数的目的

非 I/O 的异步 API

  • 定时器 setTimeout() setInterval()

  • process.nextTick()
// 立即异步执行一个任务
setTimeout(function() {
  // Todo
}, 0); // 需动用红黑树、创建定时器对象和迭代等操作,较为浪费性能

process.nextTick(function() {
  // Todo
}); // 更高效 复杂度为 O(1)
  • setImmediate()

    • process.nextTick() 类似,但是其属于 check 观察者,回调优先级低
    • process.nextTick() 的回调函数保存在一个数组中,而 setImmediate() 的结果是保存在链表中。process.nextTick()在每轮循环中会将数组中回调全部执行,而 setImmediate() 在每轮循环中执行链表中的一个回调函数

事件驱动与高性能服务器

相关文章
|
2月前
|
前端开发 JavaScript
如何处理 JavaScript 中的异步操作和 Promise?
如何处理 JavaScript 中的异步操作和 Promise?
15 1
|
2月前
|
前端开发 JavaScript 数据处理
在JavaScript中,什么是异步函数执行的例子
在JavaScript中,什么是异步函数执行的例子
10 0
|
2月前
|
前端开发 JavaScript
JavaScript的异步操作
JavaScript的异步操作
|
6天前
|
JavaScript 大数据 开发者
Node.js的异步I/O模型与事件循环:深度解析
【4月更文挑战第29天】本文深入解析Node.js的异步I/O模型和事件循环机制。Node.js采用单线程与异步I/O,遇到I/O操作时立即返回并继续执行,结果存入回调函数队列。事件循环不断检查并处理I/O事件,通过回调函数通知结果,实现非阻塞和高并发。这种事件驱动编程模型简化了编程,使开发者更专注业务逻辑,为高并发场景提供高效解决方案。
|
23天前
|
Web App开发 缓存 JavaScript
|
1月前
|
JavaScript 前端开发
JS 单线程还是多线程,如何显示异步操作
JS 单线程还是多线程,如何显示异步操作
22 2
|
3月前
|
前端开发 JavaScript
前端JavaScript中异步的终极解决方案:async/await
在深入讨论 async/await 之前,我们需要了解一下 JavaScript 的单线程和非阻塞的特性。JavaScript 是单线程的,也就是说在任何给定的时间点,只能执行一个操作。然而,对于需要大量时间的操作(例如从服务器获取数据),如果没有适当的管理机制,这种单线程特性可能会导致应用程序的阻塞。为了解决这个问题,JavaScript 引入了回调函数和后来的 Promise,用来管理这些异步操作。
|
3月前
|
前端开发 JavaScript
关于 JavaScript 的异步操作
关于 JavaScript 的异步操作
23 1
|
4月前
|
JavaScript
JS中同步和异步的区别
JS中同步和异步的区别
24 0
|
11月前
|
前端开发 JavaScript
web前端面试高频考点——JavaScript 篇(二)【JS 异步进阶】Event Loop、then 和 catch、async/await、宏任务微任务、手撕 Promise 源码
web前端面试高频考点——JavaScript 篇(二)【JS 异步进阶】Event Loop、then 和 catch、async/await、宏任务微任务、手撕 Promise 源码
146 0