nodejs如何解决高并发问题

 更新时间:2023年10月30日 09:33:19   作者:高先生的猫  
这篇文章主要介绍了nodejs如何解决高并发问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Node可以在不新增额外线程的情况下,依然可以对任务进行并发处理 —— Node.js是单线程的。

它通过事件循环(event loop)来实现并发操作,对此,我们应该要充分利用这一点 —— 尽可能的避免阻塞操作,取而代之,多使用非阻塞操作。

node单线程实现高并发原理

众所周知nodejs是单线程且支持高并发的脚本语言。

可为什么单线程的nodejs可以支持高并发呢?

很多人都不明白其原理,下面我来谈谈我的理解:

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的node为什么可以支持高并发呢?

因为I/O操作是由node的工作线程去执行的(nodejs底层的libuv是多线程的线程池用来并行io操作),且主线程是不需要等待结果返回的,只要发出指令马上就可以去忙其他事情了。   

额外知识点

  • c. 虽然nodejs的I/O操作开启了多线程,但是所有线程都是基于node服务进程开启的,并不能充分利用cpu资源

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

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

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

在过去单CPU时代,单任务在一个时间点只能执行单一程序。之后发展到多任务阶段,计算机能在同一时间点并行执行多任务或多进程。

虽然并不是真正意义上的“同一时间点”,而是多个任务或进程共享一个CPU,并交由操作系统来完成多任务间对CPU的运行切换,以使得每个任务都有机会获得一定的时间片运行。

而现在多核CPU的情况下,同一时间点可以执行多个任务,具体到这个任务在CPU哪个核上运行,这个就跟操作系统和CPU本身的设计相关了

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • NodeJS http模块用法示例【创建web服务器/客户端】

    NodeJS http模块用法示例【创建web服务器/客户端】

    这篇文章主要介绍了NodeJS http模块用法,结合实例形式分析了node.js创建web服务器与客户端,进行HTTP通信的相关操作技巧,需要的朋友可以参考下
    2019-11-11
  • nodejs同步调用获取mysql数据时遇到的大坑

    nodejs同步调用获取mysql数据时遇到的大坑

    今天小编就为大家分享一篇关于nodejs同步调用获取mysql数据时遇到的大坑,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • nodejs的http和https下载远程资源post数据实例

    nodejs的http和https下载远程资源post数据实例

    这篇文章主要为大家介绍了nodejs的http和https下载远程资源post数据实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 详解Node.JS模块 process

    详解Node.JS模块 process

    这篇文章主要介绍了Node.JS模块 process的相关资料,帮助大家更好的理解和学习node.js,感兴趣的朋友可以了解下
    2020-08-08
  • Node.js对MongoDB数据库实现模糊查询的方法

    Node.js对MongoDB数据库实现模糊查询的方法

    模糊查询是数据库的基本操作之一,下面这篇文章主要给大家介绍了利用Node.js对MongoDB数据库实现模糊查询的方法教程,文中给出了详细的介绍和示例代码,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-05-05
  • 使用Node.js实现base64和png文件相互转换的方法

    使用Node.js实现base64和png文件相互转换的方法

    这篇文章主要介绍了使用Node.js实现base64和png文件相互转换的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • 浅谈Koa2框架利用CORS完成跨域ajax请求

    浅谈Koa2框架利用CORS完成跨域ajax请求

    这篇文章主要介绍了浅谈Koa2框架利用CORS完成跨域ajax请求,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Node.js实现登录注册功能

    Node.js实现登录注册功能

    这篇文章主要为大家详细介绍了Node.js实现登录注册功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • nodejs使用express获取get和post传值及session验证的方法

    nodejs使用express获取get和post传值及session验证的方法

    这篇文章主要介绍了nodejs使用express获取get和post传值及session验证的方法,结合实例形式分析了nodejs使用express实现获取get和post传值及session验证功能的具体操作步骤与注意事项,需要的朋友可以参考下
    2017-11-11
  • Node.js包管理器Yarn的入门介绍与安装

    Node.js包管理器Yarn的入门介绍与安装

    大家都知道在yarn发布之前,所有Nodejs开发者用的都是npm包管理工具,而npm工具存在挺多难以忍受的诟病,包括安装速度慢、每次都要在线重新安装等问题,而yarn也是为了解决npm当前所存在的问题而出现的。本文给大家介绍了包管理器Yarn,以及安装方法。下面来一起看看。
    2016-10-10

最新评论