详解node单线程实现高并发原理与node异步I/O

网友投稿 460 2023-04-01


详解node单线程实现高并发原理与node异步I/O

一、node单线程实现高并发原TZrvZZ理

众所周知nodejs是单线程且支持高并发的脚本语言。可为什么单线程的nodejs可以支持高并发呢?很多人都不明白其原理,下面我来谈谈我的理解:

1. node的优点:I/O密集型处理是node的强项,因为node的I/O请求都是异步的(如:sql查询请求、文件流操作操作请求、http请求...)

a. 什么是异步?

异步:发出操作指令,然后就可以去做别的事情了,所有操作完成后再执行回调

异步的实现原理:

// 第一步:定义变量

let a = 1;

// 第二步:发出指令,然后把回调函数加入异步队列(回调函数并没有执行)

setTimeout(() => {

console.log(a);

}, 0)

// 第三步:赋值,回调函数没有执行

a = 2;

// 第四步:发出指令,然后把回调函数加入异步队列(回调函数并没有执行)

setTimeout(() => {

console.log(a);

}, 0)

// 第五步:赋值,回调函数没有执行

a = 3;

// 当所有代码执行完毕,cpu空闲下来了,就会开始执行异步队列里面的回调函数

// 所以最后控制台输出:3 3

b. 什么是异步I/O?

异步I/O顾名思义就是异步的发出I/O请求

c. 虽然nodejs可以异步的发出I/O请求,但nodejs不支持多线程,为啥就可以支持高并发呢?

因为nodejs的I/O操作,底层是开启了多线程的

当同时有多个IO请求时,主线程会创建多个eio线程,以提高IO请求的处理速度

额外知识点:

d. 虽然nodejs的I/O操作开启了多线程,但是所有线程都是基于主线程开启的只能跑在一个进程当中还是不能充分利用cpu资源

pm2进程管理器可以解决这个问题

pm2 是一个带有负载均衡功能的Node应用的进程管理器.

e. cpu核数与线程之间的关系

在过去单CPTZrvZZU时代,单任务在一个时间点只能执行单一程序。之后发展到多任务阶段,计算机能在同一时间点并行执行多任务或多进程。虽然并不是真正意义上的“同一时间点”,而是多个任务或进程共享一个CPU,并交由操作系统来完成多任务间对CPU的运行切换,以使得每个任务都有机会获得一定的时间片运行。而现在多核CPU的情况下,同一时间点可以执行多个任务,具体到这个任务在CPU哪个核上运行,这个就跟操作系统和CPU本TZrvZZ身的设计相关了

2. nodTZrvZZe的缺点:不擅长cpu密集型的操作

a. 什么是cpu密集型操作(复杂的运算、图片的操作)

// 这就是一个cpu密集型的操作

for (let i = 0; i < 1000000; i++) {

console.log(i);

}

b. nodejs为什么不擅长cpu密集型操作

因为nodejs是单线程的


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:shiro之记住登录信息
下一篇:接口测试用例传参怎么写(接口测试用例包含哪些内容)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~