一、概念
Node.js简称Node,是一个可以使JavaScript运行在服务器端的开发平台。
JavaScript本是一种Web前端语言,Node.js让JavaScript成为服务器端脚本语言。
Node.js选择JavaScript作为实现语言的原因:
JavaScript满足CommonJS标准,符合事件驱动,用户较多且门槛较低;
Chrome的V8引擎具有出色的性能。
Node.js将V8引擎封装起来,作为服务器运行平台,以执行JavasScript编写的后端脚本程序。
Node.js是跨平台的,能运行在Windows、macOS和Linux平台上。
Node.js除了自己的标准类库之外,还可使用大量的第三方模块系统来实现代码的分享和重用。
与其他后端脚本语言不同的是,Node.js内置了处理网络请求和响应的函数库,也就是自备了HTTP服务器,所以不需要额外部署HTTP服务器。
二、node.js的特点
1、非阻塞I/O
非阻塞I/O又称异步式I/O,是Node.js的重要特点。
阻塞I/O是指线程在执行过程中遇到I/O操作时,操作系统会撤销该线程的CPU控制权,使其暂停执行,处于等待状态,同时将资源转让给其他线程。
非阻塞I/O是指当线程遇到I/O操作时,不会以阻塞方式等待I/O操作完成或数据返回,而只是将I/O请求转发给操作系统,继续执行下一条指令。
2、事件驱动
非阻塞I/O是一种异步方式的I/O,与事件驱动密不可分。
事件驱动以事件为中心,Node.js将每一个任务都当成事件来处理。Node.js在执行过程中会维护一个事件队列,需执行的每个任务都会加入事件队列并提供一个包含处理结果的回调函数。
在事件驱动模型中,会生成一个事件循环线程来监听事件,不断地检查是否有未处理的事件。
Node.js的异步机制是基于事件的,所有磁盘I/O、网络通信、数据库查询事件都以非阻塞的方式请求,返回的结果由事件循环线程来处理。
3、单线程
Node.js的应用程序是单进程、单线程的,但是通过事件和回调支持并发,性能变得非常高。
在阻塞模式下,一个线程只能处理一项任务,要想提高吞吐量必须使用多线程。
在非阻塞模式下,线程不会被I/O操作阻塞,该线程所使用的CPU核心利用率永远是%,I/O操作以事件的方式通知操作系统。
Node.js在主线程中维护一个事件队列,当接收到请求后,就将该请求作为一个事件放入该队列中,然后继续接收其他请求。
Node.js内部通过线程池来完成非阻塞I/O操作,Node.js的单线程是指对JavaScript层面的任务处理是单线程的,而Node.js本身是一个多线程平台。
Node.js采用非阻塞I/O与事件驱动相结合的编程模式,与传统同步I/O线性编程思维有很大的不同,Node.js程序的控制很大程度要依靠事件和回调函数,这不符合开发人员的常规线性思路,需要将一个完整的逻辑拆分为若干单元(事件),从而增加了开发和调试的难度。
三、node.js的应用场合
RESTAPI:RESTAPI是一种前后端分离的应用程序架构。
单页Web应用:加载单个HTML页面,并在用户与应用程序交互时动态更新该页面的Web应用程序。
统一Web应用的UI层:Node.js是面向服务的架构,其能够更好地实现前后端的依赖分离,可以将所有的关键业务逻辑都封装成RESTAPI,UI层只需要考虑如何用这些API构建具体的应用。
准实时系统:如聊天系统、微博系统、博客系统的准实时社交系统,特点是轻量级、高流量,没有复杂的计算逻辑。
游戏服务器:程序员不必使用C语言就能开发游戏的服务器程序。
微服务架构:Node.js也可用于实现基于微服务架构的应用。