从web架构来认识nodejs

nodejs出现的时候,我有一种冲动,就是在jquery和nodejs之间进行选择,最后选择了jquery,那时我以为nodejs不过是和jquery一样的一种js库,运行在服务端,听上去很牛逼,说不定也就那样。但随着npm的出现,nodejs的世界瞬间把jquery甩到九霄云外,nodejs早已超出Javascript的范畴,实际上,nodejs诞生的那天开始,就不是专为Javascript而生的。

用Javascript作为后端语言

在我们以往的web开发中,我们经常会使用php作为服务端开发语言,我们称之为后端(backend)而使用css、js解决页面的展示,我们称之为前端(frontend)。但随着nodejs的盛行,Javascript也可以开始作为后端语言,在服务器上运行。这其实很好理解,以前我们使用php test.php在服务器上运行php文件,而现在我们使用nodejs test.js在服务器上运行js文件,js的功能和php的功能一样的,只不过用不同的运行环境去运行它。但这种环境的改变,可能会给开发行业带来巨大的变化,因为以前专注于前端的开发人员,将很快从web界面这个狭小的领域,渗透到服务端、客户端(原生APP)的开发中,这我会在下文慢慢讲到。

在服务端运行js文件对于以前一直专注于浏览器前端的程序员其实有点难以理解,Javascript怎么在服务器上跑起来呢?为了突破这一阻碍,我们现在假设node运行的不是Javascript,而是另外一个叫test.nd的程序,而这个.nd程序的语法竟然和Javascript一摸一样,连它的机理、特性、线程都一摸一样,这时你才反应过来,它就是Javascript,不是别的。没错,在浏览器上面,Javascript是程序,由浏览器的脚本引擎去解释执行,而在服务器上,Javascript还是程序,由nodejs去负责执行,浏览器的api和nodejs的api可不一样,因此在浏览器端写的js代码,有的可以在nodejs环境中执行,而有的则不可以,nodejs环境中写的js,大部分是不能直接用在浏览器中运行的。

在nodejs环境中开发时,前端页面上要用的js和在服务器上运行的js要分开,前者可以按照你以前的写代码方式,无需任何改变,而后者,就不必须按照nodejs所遵循的CMD规范来写。现在,如果你打算在服务器上一展身手,忘记你曾经在浏览器环境下开发js时的一切,你现在已经掌握了js的语法、特性、机理,接下来,你只需要掌握nodejs的开发规范(或者你可以理解为框架里面的特定写法,同时使用一些特殊的api),就可以开始使用Javascript来操作你的服务器执行一些牛逼的动作了。

基于NodeJS的web架构

当我们没有nodejs之前,我们一般想到的是我们传统所说的3P(asp, php, jsp)。以php为例,我们写一个网站,首先要有数据库,然后使用php去连接数据库,查询出数据,然后用php混杂着html代码,把页面的layout打印在浏览器上,再用css、js去实现界面的效果渲染。我们可以用一幅画来画出这个架构模型:

tranditional-web-construct

而当我们有了nodejs后,我们可以把web架构改成如下的形式:

nodejs-web-construct

nodejs在服务器端,直接像前端提供layout和data,成为前端和服务器打交道的直接对象。另外,nodejs自己提供了服务器环境,无需安装apache就可以像用户提供服务。

但是在上面这个模型中,你会看到,在nodejs和数据库之间,仍然存在一个需要由其他程序完成的数据连接和处理过程,这是因为目前nodejs直接操作数据库的功能还不成熟,因此在大部分项目中,使用其他语言去查询、添加、修改数据库中的数据,并向nodejs中运行的js提供data api,再由nodejs完成所有的逻辑处理。

精简一点,我们可以把上面的模型简化为:

nodejs-web-construct-simple

在这个简化的模型图中,与之前的传统模型中相比,就是独立多出了NodeJS的部分,看上去没有什么改进。但实际上,这种变化的巨大的,因为NodeJS拥有非常不同的异步I/O的特性,所以它才在众多环境中逐渐上升,NodeJS的特性是它之所以被越来越多的开发者接受和喜爱的根本原因。而这个模型的意义除了把NodeJS作为和前端交互的一个中介之外,还有一个重要的意义,就是在整个web开发中,Javascript将占据更大的比例,而php等原来的后端语言,会退缩到只和数据库打交道的位置,不再参与业务逻辑的处理,这就压缩了原来作为后端语言盛行的一些语言。当然,其实这也是一个契机,可以让这些语言更加专注于做它所具备的特质的事。

Javascript不仅向后端扩展,而实际上,在往APP开发的道路上,js也一直昂首阔步,Native.js, React Native等项目声名鹊起,使得APP开发者也受到了来自前端的压力。

当然nodejs还有一些不足之处,这是作为一门新兴技术,不可避免的,我们希望它有一天可以实现和数据库稳健的交互,这样通晓一门Javascript,将可以在未来各个领域发挥作用。

NodeJS还可以干什么

除了作为web的用途之外,nodejs其实还有其他的用处,因为nodejs不是Javascript,nodejs是一个程序、一个软件、一个环境,它是可以运行js代码的程序,甚至可以把它称为js的一种解释器(编译器),用js写的代码,不仅可以实现和web相关的功能,甚至可以实现和其他大部分语言一样的功能,甚至做的更优秀。下面是我总结的一个方面:

nodejs-feature

nodejs可以实现编译、数据运算、开发环境等功能,这使得无论是nodejs也好,还是js也好,都将在将来大为有用,甚至因此出现更加让人惊叹的新产品。

2016-05-19

已有4条评论
  1. […] 随着前后端分离的思想出现之后,上面这种完全后端主导的局面也逐渐瓦解了,前后端分离是指前端和后端专注(甚至只)做一件事,所以在我写的《从web架构来认识nodejs》这篇文章里,就勾画了大致的新的前后端分工: […]

  2. […] 随着前后端分离的思想出现之后,上面这种完全后端主导的局面也逐渐瓦解了,前后端分离是指前端和后端专注(甚至只)做一件事,所以在我写的《从web架构来认识nodejs》这篇文章里,就勾画了大致的新的前后端分工: […]

  3. loszer 2017-09-16 16:39

    有部分说的不太合适,有了nodejs取代了前端显示的职责后(附带处理部分轻量的业务逻辑),php、java这些语言依然负责主要的业务逻辑并且提供给nodejs以接口。

    • 否子戈 2017-09-17 13:27

      谢谢指出