结论
1)Node是使用了v8引擎的服务器端,主要采用C/C++实现底层,底层libuv为多线程,执行不同的I/0任务
2)Node中v8引擎的JavaScript实现事务,是单线程的,每一个请求进入线程队列,若为IO则分给线程池执行,并等待结果,否则自己执行,另外:队列在单线程无新的请求的时候,所有事件开始循环执行(结束出队)
图解:JavaScript所在的v8是单线程的,即上述2中描述的,事务在这里排队,循环执行,IO交给LIBUV执行,执行结束后告诉单线程结果
优势
底层可以多线程执行IO操作,不会阻塞,模拟了异步操作(真正的异步是多进程,或者多线程,注意,我们的node单线程,JavaScript只有单线程,没有多线程)
所以Node很适合开发IO密集,高并发的任务,对于CPU密集型的操作相对较弱,比如图形处理等(也是因为JavaScript的单线程,导致他只能操作一个CPU内核进行计算,限制了性能)
补充
劣势解决方案(以下内容仅供参考)
- 同时开启多个进程来监听同一个端口,分发http请求处理