CPU密集型任务会阻塞 Node.js 吗
时间:2022-07-22
本文章向大家介绍CPU密集型任务会阻塞 Node.js 吗,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
CPU密集型任务会阻塞 Node.js 吗?
让我们使用加密任务做个简单测试:
如图所示,连续执行四次加密任务,打印耗时,结果会发生什么?
结果输出:
Hash: 1232Hash: 1237Hash: 1268Hash: 1297
这四次加密任务计时的起始时间都是相同的,然后最终的结束时间却几乎一致,这个结果说明了什么?说明它们是并发执行的。
如果不是并发执行,那么结果就会如下图所示:
那么为什么这里没有发生阻塞?
Node.js 的执行过程如上图所示,我们要注意的是 libuv 默认使用了四个线程!上述示例中的四个加密任务分别推送到了四个不同的线程中去并发执行,所以才没有发生阻塞。
那么问题来了?如果连续执行五个加密任务呢?
输出结果:
Hash: 1432Hash: 1437Hash: 1468Hash: 1497Hash: 2104
可以看到前四个任务仍然是并发执行的,但是第五个任务发生了阻塞。
为什么?因此 libuv 的四个线程都在忙碌,第五个任务只有等待线程的任务执行完毕才能推送到线程中去执行。
过程如下图所示:
1、四个线程都在忙碌,其它任务必须等待:
2、某个线程任务完成,继续执行其它任务:
libuv 线程池中的线程数量是否可以设置?
通过环境变量 UV_THREADPOOL_SIZE 即可设置。
比如:
我把线程数设置为 5 ,执行的结果就会是下图所示:
请注意测试环境的 CPU 核心数是四个,需要说明的有两点:第一,五个任务被推送到了五个线程中去并发执行,这一点上文已经说明;第二,每个任务的耗时有了明显的增加,为什么?因为我们只有四核,但是却有五个线程,操作系统需要进行平衡调度、通过上下文切换以保证每个线程分配到相同的时间去执行任务。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法