首页 >

为什么node能高并发

web前端|前端问答为什么node能高并发
node
web前端-前端问答
值班管理系统asp源码,vscode无故报错,which ubuntu,tomcat 首页修改,sqlite怎么存时间,asp.net插件开发,web数据字典前端框架,数据爬虫应用领域,php 字段 数组,廊坊seo整站优化,动态个人网站模板,手机 网页转pdf插件,emlog模板修改教程lzw
为什么node能高并发
王者视频站源码,ubuntu怎么读音标,安装tomcat9教程,爬虫 网页gzip,php发送邮件功能,晋安区网页seo费用是多少lzw
nodejs是非阻塞异步操作。针对每个并发请求,服务端给请求注册一个激发事件(I/O),并给一个回调函数(这个过程没有阻塞新的连接请求)。按顺序执行事件处理(I/O),处理完成后执行回调函数,接着执行下一个事件处理(I/O)。
android源码大全,vscode怎么使用vv3,ubuntu卸载wine,tomcat损坏文件,sqlite空间查询,网页设计师开工作室,cmd怎么控制服务器,js相册插件,前端ts框架,轻松筹爬虫,php获取图片信息,seo去哪里学,springboot的添加,关于幼儿园的网站模板,网页制作模板使用,苹果cms模板生成静态,dedecms网站后台模板,手机端与pc端页面html5,安卓简易图书管理系统,huffman编码c语言程序lzw
在解释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能高并发

《nodejs视频教学》


  • 暂无相关文章
  • Posted in 未分类