nodejs为什么可以高并发?

nodejs可以高并发的原因:nodejs是非阻塞异步操作。针对每个并发请求,服务端给请求注册一个激发事件(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,整个系统都崩溃;

以上就是nodejs为什么可以高并发?的详细内容,更多请关注易知道|edz.cc其它相关文章!

推荐阅读