node能高并发的原因是什么


本篇内容主要讲解“node能高并发的原因是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“node能高并发的原因是什么”吧! 因为node具有“事务驱动”和异步“I/O”特性,是非阻塞异步操作;针对每个并发请求,服务端给请求注册一个激发事件,并给一个回调函数,按顺序执行事件处理,处理完成后执行回调函数,接着执行下一个事件处理,所以node能够高并发。本教程操作环境:windows10系统、nodejs 12.19.0版本、Dell G3电脑。nodejs是非阻塞异步操作。针对每个并发请求,服务端给请求注册一个激发事件(I/O),并给一个回调函数(这个过程没有阻塞新的连接请求)。按顺序执行事件处理(I/O),处理完成后执行回调函数,接着执行下一个事件处理(I/O)。在解释node为什么能够做免费云主机域名到高并发之前,不妨先了解一下node的其他几个特性:单线程我们先来明确一个概念,即:node是单线程的,这一点与JavaScript在浏览器中的特性相同,并且在node中JavaScript主线程与其他线程(例如I/O线程)是无法共享状态的。单线程的好处就是:无需像多线程那样去关注线程之间的状态同步问题没有线程切换所带来的开销没有死锁存在当然单线程也有许多坏处:无法充分利用多核CPU大量计算占用CPU会导致应用阻塞(即不适用CPU密集型)错误会引起整个应用的退出异步I/O你可能会问,既然node是单线程的,事件全部在一个线程上处理,那不是应该效率很低、与高并发相悖吗?恰恰相反,node的性能很高。原因之一就是node具有异步I/O特性,每当有I/O请求发生时,node会提供给该请求一个I/O线程。然后node就不管这个I/O的操作过程了,而是继续执行主线程上的事件,只需要在该请求返回回调时在处理即可。也就是node省去了许多等待请求的时间。这也是node支持高并发的重要原因之一实际上不光是I/O操作,node的绝大多数操作都是以这种异步的方式进行的。它就像是一个组织者,无需事必躬亲,只需要告诉成员们如何正确的进行操作并接受反馈、处理关键步骤,就能使得整个团队高效运行。事务驱动你可能又要问了,node怎么知道请求返回了回调,又应该何时去处理这些回调呢?答案就是node的另一特性:事务驱动,即主线程通过event loop事件循环触发的方式来运行程序这是node支持高并发的另一重要原因到此,相信大家对“node能高并发的原因是什么”有了更深的了解,不妨来实际操作一番吧!这里是百云主机网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

相关推荐: Java Stream流怎么生成和操作

本文小编为大家详细介绍“JavaStream流怎么生成和操作”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaStream流怎么生成和操作”文免费云主机域名章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。需求:按照要求集合创建和遍历…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 04/24 10:50
下一篇 04/24 11:20

相关推荐