node如何实现高并发? - 网站

node如何实现高并发?

分类:Node.js常见问题 · 发布时间:2019-08-05 13:57 · 阅读:2669

nodejs是非阻塞异步操作。node具有异步I/O特性,每当有I/O请求发生时,node会提供给该请求一个I/O线程。然后node就不管这个I/O的操作过程了,而是继续执行主线程上的事件,只需要在该请求返回回调时在处理即可。也就是node省去了许多等待请求的时间。

node特点:

1、Chrome V8引擎

2、事件驱动

3、非阻塞 I/O

4、单线程

node实现高并发的方法:

针对每个并发请求,服务端给请求注册一个激发事件(I/O),并给一个回调函数(这个过程没有阻塞新的连接请求)。

按顺序执行事件处理(I/O),处理完成后执行回调函数,接着执行下一个事件处理(I/O)。

事件处理(I/O)原理?

事件处理(即异步I/O处理)是由node工作线程去执行的(nodejs底层的libuv是由多线程的线程池并行I/O操作),且主线程是不需要等待返回的,只要发出指令后就可以执行其他事件,所有操作完成后执行回调。

NodeJS的优缺点

优点:

1、高并发;

2、适合I/O密集型应用。

缺点:

1、不适合CPU密集型应用,只支持单核CPU,不能充分利用CPU;

2、单进程,单线程,一旦代码某处出现bug,整个系统都崩溃;

如何解决CPU密集型?

原因,由于JavaScript单线程的原因,如果有长时间运行的计算(比如大循环),将会导致CPU时间片不能释放,使得后续I/O无法发起。

解决方案:分解大型运算任务为多个小任务,使得运算能够适时释放,不阻塞I/O调用的发起。

单进程、单线程解决方案

Nnigx反向代理,负载均衡,开多个进程,绑定多个端口;

开多个进程监听同一个端口,使用cluster模块。

标签:
node

相关文章

如何设置 nodejs 的环境变量

在前端开发过程中,我们需要对 application 运行的环境进行设置,一般会包括开发环境development,生产环境production,每个环境可以对应不同的一些配置,例如不同环境下请求的地址...

谈谈Node.js与JavaScript的差异

Javascript是一种web前端语言,主要用于web开发中,由浏览器解析执行。Node.js是一个可以快速构建网络服务及应用的平台,是用Javascript语言构建的服务平台。

npm install安装报错怎么解决?

解决方法:1、报“operation not permitted”错误,通过“npm i 包名 --no-optional”解决;2、报“Missing: chromedriver”错误,表示没有安装chromedriver,安装一下即可。

怎么使用npm下载vue.js?

使用npm下载vue.js的方法:1、安装node.js和npm;2、安装cnpm;3、使用命令cnpm install -g vue-cli来安装即可。

vue.js和node.js是什么关系?

vue.js和node.js并没有关系,vue.js是前端框架,算是js的三大框架之一吧,node.js是后端开发语言,同php、java、c#一样的。但是他们可以配合使用。

返回分类 返回首页