位置: 编程技术 - 正文

解析NodeJS异步I/O的实现(nodejs获取异步请求返回值)

编辑:rootadmin

推荐整理分享解析NodeJS异步I/O的实现(nodejs获取异步请求返回值),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs 异步,nodejs 异步io底层原理,nodejs 异步,node 异步,nodejs 异步,nodejs 异步io底层原理,nodejs 异步,nodejs 异步io底层原理,内容如对您有帮助,希望把文章链接给更多的朋友!

在现在的项目开发中,任何一个大型项目绝对不是简简单单的采用一个种语言和一种框架,因为每种语言和框架各有优势,与其死守一个,不与取各家之所长,依次得到一个高性能、搞扩展的产品。

对于一个.NET开发者,尤其是主要从事Web开发的.NET程序员,个人觉得有必要学习一门性能优越的Web平台开发语言。一个开发者不能简简单单的只学习一门语言,思维应该开阔,从各个方面去看待同样的一个问题,这样或许会得到另一番效果和见解,个人认为应该学习一下其他的语言,这样有利于我们对比语言的优势和缺点,例如java、nodejs、python等等。对于Nodejs这个JavaScript平台,个人觉得.NET程序员有必要学习一下,因为学习NodeJS有助于我们构建一个高性能的Web平台。

NodeJS具有事件驱动、非阻塞I/O等特点,可以很好的处理I/O操作。Node面向网络且擅长并行I/O,能够有效地组织起更多的硬件资源。

这篇博客就来简单的介绍一下NodeJS的异步I/O特点。

一.NodeJS概述:

要学习一个语言或者平台,我们首先应该知道其定义,依据定义来扩展我们的学习思路。Node的定义:”一个大奖在Chrome JavaScript运行时上的平台,用于构建高速、可伸缩的网络程序。NodeJS作为一个异步事件驱动的JavaScript运行时,旨在构建可扩展的网络应用程序。“有关nodejs的背景介绍和安装方法,这里就没有必要介绍了,因为对于nodejs的安装是比较简单,所以在这里赘述就有些显得浪费时间。

学习完Node的定义特点,可能很多人都会好奇这个平台的适用场景是什么,以便在实际的项目开发中应用,不然学习这个就没有意义。主要的应用场景:前后端编程语言环境统一;高性能I/O用于实时应用;并行I/O使得使用者可以更高效地利用分布式环境;并行I/O有效利用稳定接口提升Web渲染能力;云平台的支持;游戏开发(这可能是很多开发者在意的,毕竟现在的游戏开发火热程度已经到了无以附加的地步);工具类应用,与较多的工具方法,使得开发效率大大的提升。

NodeJS异步I/O模型的基本要素:事件循环、观察者、请求对象、I/O线程池这四个共同构成。接下来我们具体了解一下这些知识。

二.NodeJS异步I/O解析:

对于Nginx服务器,很多人都是比较的熟悉,Nginx采用纯C编写而成,用于做Web服务器,在反向代理和负载均衡等服务方面有很好的优势。Node与Nginx服务器有着相似的地方,都是采用事件驱动。

浏览器中JavaScript在单线程上执行,而且还与UI渲染共用一个线程,JavaScript在执行的时候UI渲染和响应应是出于停滞状态。(如果脚本执行的时间超过毫秒,用户就会感到页面卡顿)。遇到这些情况,我们就会想到异步的方式消除这些等待的问题,对于异步和同步的概念就不做介绍了。

=接下来我们具体的来了解一下NodeJS的事件驱动和非阻塞I/O这些特点,了解这些对于我们更好的学习NodeJS开发和构建高性能的Web平台有更加深远的意义。

1.I/O操作概述:

I/O操作对于任何一个开发者来说都不会陌生,现在我们就简单的谈一下NodeJS的I.O操作。I/O操作分为:单线程串行依次执行;多线程并行执行。这两种方式各有优势和缺点,多线程的代价在于创建线程和执行期线程上下文切换的开销较大,并且多线程面临锁、状态同步的问题。单线程安装顺序执行,在执行中任何一个稍慢都会导致后续执行代码阻塞。对于任务的串行执行(概念上类似于同步执行)和任务的并行执行的描述有如下图:

解析NodeJS异步I/O的实现(nodejs获取异步请求返回值)

            

在NodeJS中利用单线程,远离死锁、状态同步问题,利用异步I/O,让单线程远离阻塞,以便更好的使用CPU。异步I/O是期望I/O的调用不再阻塞后续运算,将原有等待I/O完成这段时间分配给其他需要的业务去执行。   

很多时候一些开发者对异步/同步和阻塞/非阻塞的概念有些分不清,这两者没有什么关联。阻塞I/O是调用之后一定要等到系统内核层面完成所有操作后,调用才结束。非阻塞I/O是在调用后立即返回。关于阻塞I/O和非阻塞I/O有如下图:

2.NodeJS异步I/O解析:

事件循环:在进程启动时,Node会创建一个类似于while(true)的循环,每执行一次循环体的过程称为Tick,每个Tick的过程就是查看是否有时间待处理。

观察者:每个时间循环中有一个或多个观察者,判断是否有事件要处理的过程就是向这些观察者询问是否又要处理的事件。

请求对象:从JavaScript发起调用到内核执行完I/O操作的过渡过程中,存在一种中间产物,就是请求对象。

I/O线程池:组装好请求、送入I/O线程池等待执行,完成第一步I/O操作,进入第二部分回调通知。(在Windows中,线程池中的I/O操作调用完毕之后,会将获取的结果存在req->result属性上,然后调用PostQueuedCompletionStatus()通知IOCP,告知当前对象操作已经完成。)

异步I/O有如下图:

三.NodeJS异步编程实例:

前面介绍了异步I/O的相关概念,这里提供一个异步I/O操作的实例:

四.总结:

这篇博文是个人初次尝试NodeJS的一个小总结,如有写的不好还望大家多多的包含和指正。对于程序员来说,需要做的就是一直不停的学习,无论是否是自己主要从事的语言,对于学习多种语言,可以更加有助我们了解编程,对于一个开发者来说,最终的就是思想,因为语言的特性和框架的应用,一个熟练的编程者学习起来并不是难事,难就难在我们对于语言和框架的设计理念的理解。

从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例 本文实例讲述了Node.js基于connect和express框架的多页面实现数学运算。分享给大家供大家参考,具体如下:1、使用connect框架.use方法用于绑定中间件到conne

从零开始学习Node.js系列教程四:多页面实现数学运算的client端和server端示例 本文实例讲述了Node.js多页面实现数学运算的client端和server端。分享给大家供大家参考,具体如下:1、server端支持数学运算的服务器,服务器的返回结果

从零开始学习Node.js系列教程五:服务器监听方法示例 本文实例讲述了Node.js服务器监听方法。分享给大家供大家参考,具体如下:httpsnifferInvoke.jsvarhttp=require('http');varsniffer=require('./httpsniffer');varserver=http.creat

标签: nodejs获取异步请求返回值

本文链接地址:https://www.jiuchutong.com/biancheng/379404.html 转载请保留说明!

上一篇:从零开始学习Node.js系列教程四:多页面实现的数学运算示例(从零开始学什么)

下一篇:从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例(从零开始学什么技术)

  • 新办营利性医疗机构是否免征土地使用税和房产税?
  • 银行承兑汇票提前承兑收多少手续费
  • 资产组可收回金额包含商誉吗
  • 冲红凭证更正时摘要怎么写
  • 政府补助属于不征收收入汇算清缴怎么填写
  • 社保稳岗返还计算公式
  • 政府工会经费收入如何做凭证
  • 企业当年发放以往年度工资
  • 社保利息计入什么科目
  • 优惠政策所得税计算
  • 制造费用月末不可能有余额
  • 计提缴纳印花税怎么做账
  • 超市热卖食品
  • 水利印花税计算公式
  • 原材料的实际成本是什么
  • 奖金计提发放会计分录
  • 增值税预征率记忆口诀
  • 商品销售税金及附加会计分录
  • 财税2010121号文件有效吗
  • 企业购进货物被没收 进项税额能否抵扣?
  • 法人变更了还用变更发票领用本吗
  • 个人所得税需要计提吗?怎么做会计分录
  • 销售方开具的红字信息表
  • 以前年度损益调整会计分录
  • 进口货物需要缴纳教育费附加
  • 企业所得税税率表2023年最新
  • 转账银行汇票遗失后可以申请办理
  • 远期外汇合约套期会计分录
  • 华为分享的文件在电脑哪个文件夹
  • 本月计提增值税的金额是怎么得来的
  • 收到股改代扣代缴税款
  • ramaint.exe - ramaint是什么进程 有什么用
  • php oci
  • qcwlicon.exe - qcwlicon是什么进程 有何作用
  • 其他应收款核算内容
  • 拆除固定资产
  • php中实现文件上传的函数是什么
  • 营改增后酒店行业有哪些税种
  • php第三方包
  • 垃圾分类手工小模型
  • 鲁棒性分析方法
  • HTTP 协议
  • 城市维护建设税,教育费附加,地方教育费附加
  • 生产加工企业的成本核算
  • 购买公司支付的钱怎么做账
  • 无形资产和固定资产减值准备可以转回吗
  • 物流企业财务流程
  • 车辆购置税如何在电子税务局缴纳
  • 延期缴纳土地使用税怎么办理
  • 预付账款可以抵扣增值税么
  • 抵债不动产处置如何征税
  • 开票明细是食品类吗
  • 预收账款和应收账款的转换
  • 一般纳税人月销售额10万以下城建税
  • 库存股处理方法有哪些
  • 股东投入的资金
  • 新企业购买税控盘,没收入,怎么抵扣
  • 不动产分割要哪些步骤
  • 应计利息是什么类科目核算
  • 超过社保基数的工资怎么发放
  • 权益性无形资产包括哪些?
  • 营业外支出包括
  • 存出保证金的账务处理
  • 单位购入车辆能抵扣吗
  • win7系统设备管理器其他设备有个未知设备叹号
  • 使用删除命令删除硬盘文件后
  • http500内部错误
  • winxp修改ip地址方法
  • aix操作命令
  • ps1是什么文件
  • win7开机进入桌面黑屏但有鼠标
  • 人走鸟不惊,出自于谁的诗句?
  • node 删除文件
  • linux搭载服务器
  • Python的pycurl包用法简介
  • js中的类是什么
  • 安卓音频分析软件
  • python优先级顺序
  • 大走访 方案
  • 公务卡信用等级1级
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设