美文网首页
NodeJS为什么支持高并发、非阻塞

NodeJS为什么支持高并发、非阻塞

作者: SailingBytes | 来源:发表于2018-05-29 12:13 被阅读0次

nodejs是非阻塞异步操作。

特点

1、Chrome V8引擎

2、事件驱动

3、非阻塞 I/O

4、单线程

如何处理“高并发”请求?

针对每个并发请求,服务端给请求注册一个激发事件(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,整个系统都崩溃;

如何解决CPU密集型?

原因,由于JavaScript单线程的原因,如果有长时间运行的计算(比如大循环),将会导致CPU时间片不能释放,使得后续I/O无法发起。

解决方案:分解大型运算任务为多个小任务,使得运算能够适时释放,不阻塞I/O调用的发起。

单进程、单线程解决方案

Nnigx反向代理,负载均衡,开多个进程,绑定多个端口;

开多个进程监听同一个端口,使用cluster模块。

相关文章

  • NodeJS为什么支持高并发、非阻塞

    nodejs是非阻塞异步操作。 特点 1、Chrome V8引擎 2、事件驱动 3、非阻塞 I/O 4、单线程 如...

  • Nginx基础

    为什么要用Nginx? -跨平台、配置简单-非阻塞、高并发连接:处理2-3万并发连接数,官方监测能支持5万并发-内...

  • 基于Vercel+Github Action 部署Nest.js

    前言 完美的支持TypeScipt 面向 AOP 编程 支持 Typeorm 高并发,异步非阻塞 IO Node....

  • 2 Nodejs02 API

    1、Nodejs基本认知 ->高并发(异步I/O、非阻塞式I/O)、高性能(chrome v8引擎)、事件驱动单线...

  • JUC并发集合总结

    ConcurrentLinkedQueue 线程安全的支持高并发的队列,使用链表实现。非阻塞,无锁,无界。该队列也...

  • Go并发编程

    常见并发模型 进程 & 线程(Apache)C10K 异步非阻塞(Nginx,Libevent,NodeJS) 复...

  • Nginx--原理和基本配置

    特点 开源(BSD许可协议) 高并发 (取决于内存,linux非阻塞epoll事件模型) 支持热部署(master...

  • AtomicInteger简介

    AtomicInteger简介 支持原子操作的Integer类 主要用于在高并发环境下的高效程序处理。使用非阻塞算...

  • nodejs是什么

    nodejs是什么 nodejs是js runtime使用事件驱动 和 非阻塞I/O 模型 非阻塞I/O 阻塞:...

  • 并发、并行、同步、异步、阻塞、非阻塞

    并发 并行 同步 异步 阻塞 非阻塞

网友评论

      本文标题:NodeJS为什么支持高并发、非阻塞

      本文链接:https://www.haomeiwen.com/subject/djwojftx.html