NodeJS的优势和特点有哪些?

2023-07-0807:40:09WEB前端开发Comments909 views字数 2340阅读模式

NodeJS特点

  1. 它是一个 JavaScript 运行环境
  2. 依赖于 Chrome V8 引擎进行代码解释

ChromeV8 :文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

V8 使用 C++开发,并在谷歌浏览器中使用。在运行 JavaScript 之前,相比其它的 JavaScript 的引擎转换成字节码或解释执行, V8 将其编译成原生机器码(IA-32, x86-64, ARM, or MIPS CPUs),并且使用了如内联缓存(inline caching)等方法来提高性能。 有了这些功能,JavaScript 程序在 V8 引擎下的运行速度媲美二进制程序文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

  1. 事件驱动
  2. 非阻塞I/O
  3. 轻量、可伸缩,适于实时数据交互应用
  4. 单进程,单线程

NodeJS生态

拥有世界最大的开源库生态系统: NPM文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

NodeJS带来的对系统瓶颈的解决方案

  1. 并发连接
  • (1)系统线程模型这种模型的问题显而易见,服务端只有一个线程,并发请求(用户)到达只能处理一个,其余的要先等待,这就是阻塞,正在享受服务的请求阻塞后面的请求了。
  • (2)多线程、线程池模型这个模型已经比上一个有所进步,它调节服务端线程的数量来提高对并发请求的接收和响应,但并发量高的时候,请求仍然需要等待,它有个更严重的问题。到代码层面上来讲,我们看看客户端请求与服务端通讯的过程:

    服务端与客户端每建立一个连接,都要为这个连接分配一套配套的资源,主要体现为系统内存资源,以PHP为例,维护一个连接可能需要20M的内存。这就是为什么一般并发量一大,就需要多开服务器。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

    NodeJS是怎么解决这个问题的呢?我们来看另外一个模型。

  • (3)异步、事件驱动模型(NodeJS核心特点)我们同样是要发起请求,等待服务器端响应;

    异步操作结束后会执行后续逻辑,这个通知动作在NodeJS中叫做回调(Callback)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

    能在事件(I/O)处理完成后继续执行后面的逻辑,这体现了NodeJS的显著特点,异步机制、事件驱动整个过程没有阻塞新用户的连接,也不需要维护已连接用户和I/O操作之间的连接。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

    基于这样的机制,理论上陆续有用户请求连接,NodeJS都可以进行响应,因此NodeJS能支持比Java、PHP程序更高的并发量,虽然维护事件队列也需要成本文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

    再由于NodeJS是单线程,事件队列越长,得到响应的时间就越长,并发量上去还是会力不从心。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

    总结一下NodeJS是怎么解决并发连接这个问题的:更改连接到服务器的方式,每个连接发射(emit)一个在NodeJS引擎进程中运行的事件(Event),放进事件队列当中,而不是为每个连接生成一个新的OS线程(并为其分配一些配套内存)。

  1. I/O阻塞NodeJS解决的另外一个问题是I/O阻塞,场景:需要从多个数据源拉取数据,然后进行处理。
  • (1)串行获取数据,这是我们一般的解决方案,以PHP为例:假如获取profile和timeline操作各需要1S,那么串行获取就需要2S。
  • (2)NodeJS非阻塞I/O,发射/监听事件来控制执行过程:NodeJS遇到I/O事件会创建一个线程去执行,然后主线程会继续往下执行的,因此,拿profile的动作触发一个I/O事件,马上就会执行拿timeline的动作,两个动作并行执行,假如各需要1S,那么总的时间也就是1S。它们的I/O操作执行完成后,发射一个事件,profile和timeline,事件代理接收后继续往下执行后面的逻辑,这就是NodeJS非阻塞I/O的特点。
  • 总结:Java、PHP也有办法实现并行请求(子线程),但NodeJS通过回调函数(Callback)和异步机制会做得很自然。

NodeJS的优缺点

  • 优点:
      1. 高并发(最重要)
      1. 适合I/O密集型应用
  • 缺点:
      1. 不适合CPU密集型应用

      CPU密集型应用给Node带来的挑战主要是:由于JavaScript单线程的原因,如果有长时间运行的计算(比如大循环),将会导致CPU时间片不能释放,使得后续I/O无法发起;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

      解决方案:分解大型运算任务为多个小任务,使得运算能够适时释放,不阻塞I/O调用的发起。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

      1. 只支持单核CPU,不能充分利用CPU
      1. 可靠性低,一旦代码某个环节崩溃,整个系统都崩溃
      • 原因:单进程,单线程。
      • 解决方案:
        • (1)Nnigx反向代理,负载均衡,开多个进程,绑定多个端口;
        • (2)开多个进程监听同一个端口,使用cluster模块;
      1. 开源组件库质量参差不齐,更新快,向下不兼容;
      1. Debug不方便,错误没有stack trace。

适合 NodeJS 的场景

  1. RESTful API

这是NodeJS最理想的应用场景,可以处理数万条连接,本身没有太多的逻辑,只需要请求API,组织数据进行返回即可。它本质上只是从某个数据库中查找一些值并将它们组成一个响应。由于响应是少量文本,入站请求也是少量的文本,因此流量不高,一台机器甚至也可以处理最繁忙的公司的API需求。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

  1. 统一Web应用的UI层

目前MVC的架构,在某种意义上来说,Web开发有两个UI层,一个是在浏览器里面我们最终看到的,另一个在server端,负责生成和拼接页面。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

不讨论这种架构是好是坏,但是有另外一种实践,面向服务的架构,更好的做前后端的依赖分离。如果所有的关键业务逻辑都封装成REST调用,就意味着在上层只需要考虑如何用这些REST接口构建具体的应用。那些后端程序员们根本不操心具体数据是如何从一个页面传递到另一个页面的,他们也不用管用户数据更新是通过Ajax异步获取的还是通过刷新页面。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

  1. 大量Ajax请求的应用

例如个性化应用,每个用户看到的页面都不一样,缓存失效,需要在页面加载的时候发起Ajax请求,NodeJS能响应大量的并发请求。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

总而言之,NodeJS适合运用在高并发、I/O密集、少量业务逻辑的场景。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

结尾

其实NodeJS能实现几乎一切的应用,我们考虑的点只是适不适合用它来做。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html

作者:小宁子呀
来源:稀土掘金文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/50523.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/gcs/50523.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定