位置: 编程技术 - 正文

nodejs中实现阻塞实例(nodejs quic)

编辑:rootadmin

推荐整理分享nodejs中实现阻塞实例(nodejs quic),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs 非阻塞,nodejs解决了什么问题,nodejs quic,nodejs quic,nodejs非阻塞io,nodejs拦截器,nodejs非阻塞io,nodejs 阻塞,内容如对您有帮助,希望把文章链接给更多的朋友!

node.js中与生俱来的单线程编程、回调函数异步式风格让我们有时喜有时忧。先说单线程,很多人会费解于node.js的单线程如何能做到高并发?这个问题不是本文重点,点到为止。澄清一点,node.js的单线程仅仅指javascript引擎是单线程的,无论如何我们没有办法在javascript中实现多线程和阻塞(本文用到的方法同样不是通过V8引擎实现同步的);但对于node.js的其他方面不代表不能多线程,例如IO。如果现在node.js遭受大量请求,而这些请求都是IO密集型的,那么此时node每接受一个请求,在遇到耗时较长的IO操作时,javascript线程并不会一直在此等待,而是交出控制,在回调堆栈里添加IO操作完成后要执行的操作(当回调层级过多,访问数量过大,大量的回调链可能会爆栈)。而在这段时间内,node.js又可以处理其他请求了。所以对于node.js而言,虽然javascript是单线程的,每次只能处理一个请求,但javascript处理一个请求的时间往往较短(对于IO密集型应用而言),只要可以异步处理,那么在处理的过程中,此次请求都会释放控制,使node.js能处理其他请求。这并发请求的同时,IO其实一直处于并发状态,减少处理请求的线程数,节约资源以增加IO的线程数,对于通常耗时很长的IO密集型请求来说,无疑能带来性能上的提升。

前面???锣碌匾恢痹谇康?O密集型,其实是在强调node.js的强项。相应的,它的短板就是CPU密集型的请求。道理很简单,javascript不会并发,只能一个请求完成后才能处理其他请求。一个请求处理的时间越长,其他请求等待的时间越长。同一时间只会有一个请求被处理,并发性能很低。

话说到这儿,我想申明一点:node.js不应该被阻塞;能异步处理的方法异步处理(如使用fs.readFile(),而非fs.syncReadFile()fs.readFileSync()方法)。

nodejs中实现阻塞实例(nodejs quic)

node中不能阻塞,并不代表node外不能阻塞。前面我们有讲到fibers,现在,我们就来尝试在fibers中实现阻塞。就以处理一个http请求为例吧:

yield()、 run()这两个方法还不了解的同学,请自行查阅《fibers in node》。

fibers的运行并不在node进程中,所以在fibers内部实现阻塞对node整体的性能并没有影响。而且实现起来也是相当容易,只需要在想阻塞的时候,把fiber yield掉。需要继续运行,则执行 run()恢复fiber。在上面的例子中,我们希望当http.get请求发起时阻塞当前程序,当所有数据接收完成时,恢复程序。于是我们在调用http.get后使用 Fiber.yield()中断此fiber。在对response的监听中,如果触发 end事件表明数据传输完成,于是在 end的回调函数中,调用 Fiber.current.run()恢复fiber,这样,后续的代码就以同步的方式拿到http.get请求的数据。

上面的示例只是提供一种思路。如果对这种思路进行一些抽象封装,比如说,对有接受回调函数为参数的异步方法进行一步柯里化,在调用后中断,并劫持回调函数,以恢复程序的代码为回调函数。获取异步数据后,再程序触发预定的回调函数,这样基本能实现异步方法同步化。这段说得比较乱,基本上就是 fibers/future的实现思路,如果有兴趣,请参考其源代码。

nodejs中使用多线程编程的方法实例 在以前的博文别说不可能,nodejs中实现sleep中,我向大家介绍了nodejsaddon的用法。今天的主题还是addon,继续挖掘c/c++的能力,弥补nodejs的弱点。我曾多次

nw.js实现类似微信的聊天软件 nw.js实现类似微信的聊天软件公司qq被屏蔽,微信被屏蔽,怎么与外边通讯,你懂的。当然,也适合公司自己内部架设服务器,通讯。项目地址:freechat

node-webkit打包成exe文件被误报木马的解决方法 最近项目需要用到node-webkit。处理古老级用户的兼容以及他们心里的‘数据安全'问题。1、下载完node-webkit2、制作appName.nw文件3、copy/bnw.exe+appName.nwTestAppNa

标签: nodejs quic

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

上一篇:nodejs开发微博实例(html5仿微博代码)

下一篇:nodejs中使用多线程编程的方法实例(nodejs怎么实现多线程)

  • 商品混凝土税率为啥是3%
  • 个人买车交增值税吗
  • 注册资本 投资比例
  • 咨询公司要交税吗
  • 资产负债表里的固定资产是原值还是净值
  • 房地产企业成本分摊方法整理(附案例分析)
  • 向个人借款计入什么会计科目
  • 销售自己使用过的固定资产如何开票
  • 公司车买保险怎么付款
  • 合同方和付款方不一致,发票开付款方可以吗
  • 消费税征收环节下划的影响
  • 持有至到期投资改名为
  • 7月财务报表行次三大变化
  • 红字发票信息单需要寄给对方吗
  • 汇算清缴需要调增的费用
  • 企业所得税能否核定征收
  • 公司注销固定资产怎么处理税怎么交
  • 年终奖金计税方式区别
  • 哪些发票冲抵备用金
  • 电子税务局如何查进项发票
  • 税务机构
  • 融资租入固定资产改建支出计入
  • 手机文件打开方式怎么设置默认
  • 科技服务业是怎么分类的
  • 人力资源劳务外包合同
  • mac计算器怎么变小
  • 采购周转材料会议记录
  • 简易计税方法的适用主体有
  • 销售产品取得收入
  • 收到保险公司退款
  • yii框架教程
  • 金税盘,税控盘Ukey价格
  • paper 1
  • jquery 元素
  • 其他权益工具投资公允价值变动怎么计算
  • 个人应纳所得税计算公式
  • mysql 5.7特性
  • 被盗的固定资产如何处理
  • 短期借款属于经营活动还是筹资活动
  • 合同补充协议印花税怎么交
  • 股份支付的账务如何处理?
  • 税控盘百科
  • 企业购买汽车的进项税可以抵扣吗
  • 股东捐赠资产要纳税吗
  • 押金和租金
  • 资源税的征税对象都是原矿和选矿
  • 起征点与免征额的联系
  • 行政事业单位银行开户规定
  • 固定资产变动方式名称
  • 设备安装业绩
  • 收到退留抵税额会计分录
  • 利息收入如何做分录
  • 现金比率的计算公式是什么意思
  • 生产过程中的不良品怎么处理
  • 免抵退税额账务处理办法
  • 企业收到海河工厂发运的乙材料,并验收入库
  • 临时账户名称是什么意思
  • 工资的税额
  • 企业在非同一控制下的企业合并
  • 财务费用包括哪几项
  • 劳动者权益包含哪些
  • 企业低值易耗品的摊销方法有( )
  • 如何设计高效合理的未来课程
  • sql复合语句
  • 微软平板电脑surface pro2参数
  • win8最新版本
  • win8.1系统安装
  • 什么是边角料
  • cocos2d开发的知名游戏
  • echarts怎么样
  • bootstrap不支持ie
  • excel 级联
  • Extjs3.0 checkboxGroup 动态添加item实现思路
  • css优化提高性能的方法有哪些
  • jquery选择父级元素
  • 轻松实现的英文
  • jquery选择器大全
  • 电子税务局税务数字证书登录
  • 深圳国税咨询电话是多少
  • 一般纳税人办理退税流程及手续
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设