广告
返回顶部
首页 > 资讯 > 精选 >Nodejs中的非阻塞异步IO是什么
  • 696
分享到

Nodejs中的非阻塞异步IO是什么

2023-07-04 18:07:05 696人浏览 泡泡鱼
摘要

这篇文章主要讲解了“nodejs中的非阻塞异步io是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的非阻塞异步IO是什么”吧!我们以网络请求IO为例,首先介绍服务端处理一次

这篇文章主要讲解了“nodejs中的非阻塞异步io是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的非阻塞异步IO是什么”吧!

我们以网络请求IO为例,首先介绍服务端处理一次完整的网络IO请求的典型流程:

Nodejs中的非阻塞异步IO是什么

应用程序获得一个操作结果,通常包括两个不同的阶段:

  • 等待数据准备好

  • 从内核向进程复制数据

以下,我们以 recvfrom 函数为例,解释说明各种IO模型

阻塞式 I/O 模型(blocking I/O)

阻塞调用是指调用结果返回之前,当前线程会被挂起,调用线程只有在等待系统内核层面所有操作完成之后,调用才会结束。

阻塞I/O造成了cpu的等待I/O,浪费了CPU的时间片。

Nodejs中的非阻塞异步IO是什么

非阻塞式I/O模型(non-blocking I/O)

相比于前者,非阻塞I/O不带数据直接返回,要获取数据,还需要通过文件描述符再次尝试读取数据

Nodejs中的非阻塞异步IO是什么

阻塞调用得到返回(并不是真实的期待数据)之后,CPU时间片可以用于处理其他的事情,可以明显提升性能。

但是随之而来的问题是,之前的操作并不是一次完整的I/O,返回得到的结果不是期望得到的业务数据,而仅仅是异步调用状态。

为了获取完整的数据,应用程序需要重复调用IO操作来确认操作是否已经完成,这种操作我们称之为轮询,常见的几种轮询策略如下

忙轮询

这是最原始,也是性能最低的一种方式,通过重复调用来检查I/O状态达到获取完整数据的目的

Nodejs中的非阻塞异步IO是什么

优点:编程简单

缺点:CPU一直耗费在轮询上,同时影响服务器性能,因为你轮询之后服务器还要进行作答

I/O复用模型(I/O multiplexing)

Nodejs中的非阻塞异步IO是什么

在 I/O 复用模型中,会用到 Select 或 Poll 函数或 Epoll 函数(linux 2.6 以后的内核开始支持),这两个函数也会使进程阻塞,但是和阻塞 I/O 有所不同。

这三个函数可以同时阻塞多个 I/O 操作,而且可以同时对多个读操作,多个写操作的 I/O 函数进行检测,直到有数据可读或可写时,才真正调用 I/O 操作函数。

三种I/O复用机制的区别如下

  • select

由于select采用1024长度的数组来存储文件状态,因此最多可以同时检测1024个文件描述符

  • poll

相比select略有改进,采用链表避免了1024的长度限制,并且能避免不需要的遍历检查,相比select性能稍有改善

  • epoll/kqueue

是linux下效率最高的I/O事件通知机制,轮询时如果没有检测到I/O事件,将会进行休眠,直到事件发生将线程唤醒。它是真正利用了事件通知,执行回调,而不是遍历(文件描述符)查询,因此不会浪费CPU

Nodejs中的非阻塞异步IO是什么

小结:本质上说,轮询仍然是一种同步操作,因为应用程序仍然在等待I/O完全返回,等待期间要么遍历文件描述状态,要么休眠等待事件的发生。

信号驱动式I/O模型(signal-driven I/O)

Nodejs中的非阻塞异步IO是什么

在信号驱动式 I/O 模型中,应用程序使用信号驱动 I/O,并安装一个信号处理函数,进程继续运行并不阻塞。

当数据准备好时,程序会收到一个 SIGIO 信号,可以在信号处理函数中调用 I/O 操作函数处理数据。

小结:到此为止,信号驱动式I/O模型是更加符合我们的异步需求的,程序会在等待数据的过程中异步执行其他的业务逻辑。

但是!!! 在数据从内核复制到用户空间过程中依然是阻塞的,并不能算是一场彻底的革命(异步)。

理想中的(Node)非阻塞异步I/O

我们理想中的异步I/O应该是应用程序发起非阻塞调用,无需通过轮询的方式进行数据获取,更没有必要在数据拷贝阶段进行无谓的等待,而是能够在I/O完成之后,通过信号或者回调函数的方式传递给应用程序,在此期间应用程序可以执行其他业务逻辑。

Nodejs中的非阻塞异步IO是什么

实际的异步I/O

实际上,linux平台下原生支持了异步I/O(aiO),但是目前 AIO 并不完善,因此在 Linux 下实现高并发网络编程时都是以 I/O 复用模型为主。

windows 下通过 iocP 实现了真正的异步 I/O。

多线程模拟异步I/O

linux平台下,Node利用线程池,通过让部分线程进行阻塞I/O或者非阻塞I/O+轮询的方式完成数据获取,让某一个单独的线程进行计算,通过线程之间的通信,将I/O结果进行传递,这样便实现了异步I/O的模拟。

其实Windows平台下的IOCP异步异步方案底层也是采用线程池的方式实现的,所不同的是,后者的线程池是由系统内核进行托管的。

我们常说Node是单线程的,但其实只能说是JS执行在单线程中,无论是*nix还是windows平台,底层都是利用线程池来完成I/O操作。

感谢各位的阅读,以上就是“Nodejs中的非阻塞异步IO是什么”的内容了,经过本文的学习后,相信大家对Nodejs中的非阻塞异步IO是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Nodejs中的非阻塞异步IO是什么

本文链接: https://www.lsjlt.com/news/346783.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Nodejs中的非阻塞异步IO是什么
    这篇文章主要讲解了“Nodejs中的非阻塞异步IO是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Nodejs中的非阻塞异步IO是什么”吧!我们以网络请求IO为例,首先介绍服务端处理一次...
    99+
    2023-07-04
  • 带你了解Nodejs中的非阻塞异步IO
    以上就是带你了解Nodejs中的非阻塞异步IO的详细内容,更多请关注编程网其它相关文章!...
    99+
    2023-05-14
    I/O模型 node
  • Python中的同步异步阻塞与非阻塞是什么
    今天小编给大家分享一下Python中的同步异步阻塞与非阻塞是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、状态介绍在...
    99+
    2023-07-05
  • 什么是异步非阻塞redis
    异步非阻塞redis又叫异步IO,在IO多路复用模型中,事件循环将文件句柄的状态事件通知给用户线程,由用户线程自行读取数据、处理数据。而在异步IO模型中,当用户线程收到通知时,数据已被内核读取并存储于用户线程指定的缓冲区内,内核在IO完成后...
    99+
    2022-10-05
  • Java非阻塞IO和异步IO的详细介绍
    这篇文章主要讲解了“Java非阻塞IO和异步IO的详细介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java非阻塞IO和异步IO的详细介绍”吧!阻塞模式 IO我们已经介绍过使用 Java...
    99+
    2023-06-02
  • linux阻塞与非阻塞的概念是什么
    在Linux系统中,阻塞和非阻塞是指对于输入/输出(I/O)操作的处理方式。阻塞(Blocking)是指当程序发起一个I/O操作时,...
    99+
    2023-09-16
    linux
  • php程序阻塞与非阻塞的区别是什么
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php程序阻塞与非阻塞的区别是什么阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态.阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结...
    99+
    2017-08-28
    php
  • Node.js中非阻塞I/O是什么
    本篇文章为大家展示了Node.js中非阻塞I/O是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。先新建一个index.js,再打开我们前端人的vs-code,打...
    99+
    2022-10-19
  • Python异步在非阻塞子进程中运行命令的方法是什么
    今天小编给大家分享一下Python异步在非阻塞子进程中运行命令的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1....
    99+
    2023-07-05
  • 什么是Javascript引擎和运行时以及单线程与非阻塞和异步以及并发语言分别是怎样的
    这篇文章将为大家详细讲解有关什么是Javascript引擎和运行时以及单线程与非阻塞和异步以及并发语言分别是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了...
    99+
    2022-10-19
  • NodeJs异步编程的含义是什么
    本文小编为大家详细介绍“NodeJs异步编程的含义是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“NodeJs异步编程的含义是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2022-10-19
  • Java中常用阻塞队列的问题是什么
    本篇内容主要讲解“Java中常用阻塞队列的问题是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中常用阻塞队列的问题是什么”吧!Java常用阻塞队列ArrayBlockingQueue...
    99+
    2023-06-29
  • Nodejs异步编程中的Promise有什么作用
    这篇文章主要介绍“Nodejs异步编程中的Promise有什么作用”,在日常操作中,相信很多人在Nodejs异步编程中的Promise有什么作用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2022-10-19
  • Python中同步与异步的区别是什么
    今天就跟大家聊聊有关Python中同步与异步的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. “同步”和“异步”是什么意思?Web 应...
    99+
    2022-10-19
  • Android中同步与异步的关系是什么
    本篇文章为大家展示了Android中同步与异步的关系是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。android 只有UI线程可以刷新界面,其他副线程不行,这样就需要副线程通过通信消息修改刷新...
    99+
    2023-06-19
  • Java中检查型异常与非检查型异常的区别是什么
    本篇文章给大家分享的是有关Java中检查型异常与非检查型异常的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。     ...
    99+
    2023-05-31
    java 别是 ava
  • Vue中的同步和异步调用顺序是什么
    今天小编给大家分享一下Vue中的同步和异步调用顺序是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vue的同步和异步调用...
    99+
    2023-06-28
  • Vue 中异步更新的原理是什么
    今天就跟大家聊聊有关Vue 中异步更新的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Vue 异步更新 DOM 原理很多同学都知道,Vue...
    99+
    2022-10-19
  • C#中异步调用的原理是什么
    本篇文章为大家展示了C#中异步调用的原理是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C#异步调用是什么呢?具体的内容又是什么呢?让我们开始C#异步调用的学习吧计算机中有些处理比较耗时。调用这...
    99+
    2023-06-17
  • Python中的异步编程算法是什么?
    Python中的异步编程算法是指一种能够提高程序效率的编程方法,它可以在程序执行某个任务时,同时执行其他任务,从而实现并发执行。在Python中,异步编程通常使用asyncio模块来实现。 异步编程的核心是事件循环,它负责调度任务的执行。在...
    99+
    2023-07-08
    对象 异步编程 编程算法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作