2009 年 8 月,CommonJS规范标准出台,针对JavaScript脚本语言作为服务器端开发语言实现标准化,制定JavaScript脚本语言作为服务器端语言所必需的规则。Ryan Dahl推出了NodoJS,是第一个服务器端JavaScript脚本语言开发框架,并且严格遵循CommonJS规范标准。NodeJS语言可以运行在服务器端,依据的是Google开发的V8 高性能JavaScript脚本语言。由于V8 引擎自身优越的解析能力,以致NodeJS服务技术发展迅速,性能优越,同时还提供了丰富的第三方库。
此外,通过单线程实现异步处理是NodeJS最重要的特征之一。通常,对于异步操作处理,开发工程师想到的是采用多线程服务在服务器端编译,然而NodeJS,本就由事件和异步组成,其异步机制是由事件和回调函数实现。这里说的异步,确切的说连续异步。
NodeJs单线程异步的特性,直接导致多个异步同时进行时,无法确定最后的执行结果来回调。回调是一个函数,每个异步操作时将计数器+1,当每个异步结束时将计数器-1,通过判断计数器是否为 0来确定是否执行回调。这个逻辑很简单,需要一个相对于执行时和回调时的全局变量作为计数器,而且要在传给异步方法是执行+1 的操作,而且之后将返回一个用来回调的函数,这也是JavaScript语言的高级使用方法[5]。 服务器高并发的概念,对于Web应用开发者并不陌生,这也是长久以来困扰开发者的难题。在一定时间内存在至少两个以上的客户端请求或者用户请求,对后端服务器有着持续性的高占有率,当这些占有率达到一定的界点时,也就是达到一定的临界点,系统的整体应用性能会出现两种情况,一种是维持原状,一种是性能直线下降。那么要在现有存在的资源下,降低请求量,尽最大可能提高资源的利用率,提高应用系统性能,如何实现系统的高并发要求,这也是促使NodeJS问世的最主要原因[6]。 通常为了解决上述问题,开发者会首先考虑从硬件角度出发,选择优良的应用服务器,着重从大内存、大硬盘、多CPU角度出发。或者考虑对应用整体架构做出调整,增加应用整体架构自身的抗压能力,多一些应用资源进行适当减少。然而,仅仅从硬件方面考虑提高系统应用性能或者减少资源利用是一般的解决方案。但是从应用整体架构出发,开发高性能的应用架构才是解决问题的根本方法[7]。 作为一门后端编程语言,NodeJS自然提供出了很多的网络服务,包含HTTP、DNS、NET、UDP等等,研发工程师在此根本上就可以很快的研发出适用于自己的Web后端服务器[ 8]。 NodeJS的网络编程比较便利,拥有的服务预留了简单易读写的API入口文件,只需几行js语言就能构建服务器。 对于应用程序需要处理多并发的请求与响应,同时在向浏览器端做出应答之前,应用程序内部没有必要进行十分复杂操作时,那么此时选取 NodeJS 作为该应用程序后端服务器的开发是十分恰当的。另外,NodeJS 是基于 JavaScript 脚本语言的网络开发应用平台,处理机制并不是多线程,因为 JavaScript 脚本语言是基于单线程实现的。换句话说,Web 应用开发者使用 NodeJS 作为后端服务部署,不用担心因多线程带来的切换不同层之间的联系以及高并发带来的影响,反而使得后端机制变得简便,开发者处理后端服务也变得更为容易。 本文以 JavaScript 语言作为核心开发语言,利用 NodeJS 网络应用平台做后端服务平台,统一前后端开发语言,同其他前沿开发技术一起,构建一个自适应浏览器、高性能、实用且具有现实意义的面向 Web 应用开发者的 Web 应用平台。