但愿这篇文章为你们对 Node.js 后端框架选型带来一些帮助。前端
JavaScript 这门语言的设计虽然被不少人诟病,可是由于其占据了浏览器并且容易上手因此普遍流行。后来随着 Node.js 的出现,npm 包管理带来的强大生态更是如虎添翼(截止到 2017 年 3 月 npm 共有 43 万个包)。可是这也形成了 JS 社区变态的快速迭代,你们都直呼赶不上,框架太多,选择太多,眼花缭乱。node
下图是 2016 年 Node.js 开发框架的发展势头排名(基于 Github 上 2016 年增长的 star 数)。git
关于上图的更多细节可查看 2016 JavaScript Rising Stars。github
Tip: 能够经过网站 npms.io 快速了解一个 npm 包的质量。更多如何肯定一个包的质量,能够参考《如何挑选高质量的 Node.js 模块?》web
下面结合上图简单介绍一下各个框架。数据库
Meteor
很奇怪前面提到的 2016 JavaScript Rising Stars 竟然没有把 Meteor 列入。Meteor 目前在 Github 上已是 star 最多的 web app 开发框架了。注意不是仅限于 JS 范围哦。它已经超越了 Ruby 的 Rails 和 PHP 的 Laravel。(参考 Github web app frameworks Rank)。固然星星多并不能说明所有问题。Meteor 最近动做很少,多是他们团队在忙着开发基于 GraphQL 的 Apollo 框架的缘由。(建议你们关注一下 Apollo,感受会对先后端交互带来很大的革新)。npm
Meteor 是一个有点 ‘异类’ 的全栈框架。首先它先后端通讯使用 WebSocket 而不是 HTTP,因此实时性很好,但它不是一个 REST 框架,虽然能够经过简单的改造,提供 RESTful API;第二 Meteor 绑定了 MongoDB,让喜好关系型数据库的同窗爱不起来。不过如今 Meteor 也可使用 Apollo 和关系型数据库交互了,比 REST 架构还方便。可是 Apollo 目前还处于开发阶段。后端
Express 和 Koa
这两个是 Node.js 最基础的后端框架。由于太基础,因此构建一个 app 仍须要写不少脚手架代码,因而在它们基础之上出现了不少其余框架来减小编写这类代码。Express 应该是装机量最多的,而 Koa 更新一些, 使用的技术更新颖,例如 promises 和 async function,再也不有回调函数嵌套的问题了。api
Feathers.JS
Feathers.JS 构建与 Express4.0 基础之上,Express 的那些中间件都能在 Feathers 里直接使用。Feathers 另外特色是兼容 WebSocket 的实时性和 HTTP 的 REST。不过注意用户鉴权默认使用 JWT,而不是传统的 session。我以为 JWT 更适合大一点的项目,例若有移动端须要调用 API。promise
Nodal
和 PostgreSQL 绑定。对这个框架不熟悉,感受是为 stdlib.com 这个云服务商定制的,比较封闭的一个框架。
KeystoneJS
KeystoneJS 是一个 CMS 框架,有点像 PHP 的Drupal,功能全面,适合作后台管理,内容管理。自带的用户管理功能很方便。
LoopBack
LoopBack 是由 StrongLoop 公司基于 Express 开发的开源框架。前年被 IBM 收购了。这是一个大而全的企业级框架,适合有多种终端,还有与其余后端服务集成的场景。这篇文章解释了 LoopBack 为何火不起来? 。主要观点是由于目前大系统都仍是 Java 框架的天下,Node.js 更可能是应用在前端和中间层。
不少人把它和 hapi 比较,由于都是用来开发 RESTful API。我我的认为 LoopBack 火不起来的缘由是它限制有点多,不像 hapi 那么灵活,hapi 更适合当下快速迭代的开发方式。
Sails 和 Trails
从名字看应该都是向 Ruby 的 Rails 学习的 MVC 框架,以前没有用过 Rails,因此对他们没有太多了解。估计适合从 Ruby on Rails 转过来的同窗。
hapi 和 restify
从名字能够看出是构建 RESTful 服务的框架,适合后端是微服务的架构。两者我的更倾向于 hapi(来自沃尔玛团队),这里有一篇中文的安利 hapi 的文章。我的推荐这个框架来开发面向服务的 API。
Egg
阿里巴巴开源 (听说不是一个 KPI 开源项目) 的 Egg.js,号称为企业级框架和应用而生。它有点像 Feathers,可是基于 Koa;另外不像 Feathers,Egg 没有自带认证功能,使用 cookie/session 鉴权。更多细节能够看如何评价阿里开源的企业级 Node.js 框架 egg?。感受是一个不错的企业级 Node.js 框架。理念先进,功能也全。
Gatsby 和 Hexo
静态网站生成。适合作文档、博客类网站。比动态 web app 加载更快。Gatsby 基于 React,比 Hexo 新,维护得更好些。
那么,这么多框架到底怎么选?
关键仍是看你的应用场景。是须要一个单体的应用仍是微服务化?须要怎样的认证和受权?数据库偏好?下面说说个人浅见。
刚开始试玩 Node.js,学习 Express、Koa
若是只是想试试并学习 Node.js 开发后端服务,建议从 Express 开始,由于它够简单,并且是不少其余框架的基础,扩展也容易。若是你对 JavaScript 的 promise 和 async 熟悉,那也能够从 Koa 开始。
开发内容管理站点、简单的后台管理用 Keystone,不介意使用 MongoDB 的用 Meteor
若是你要开发一个不太复杂的内容管理应用,好比一些常常更新内容、图片的站点,用户权限等后台管理等,那么 KeystoneJS 比较合适,由于它已经内置了不少这些功能。Meteor 固然也适合。
企业应用首选 Egg
Feathers 和 Egg 都适合开发企业应用。有日志、安全、多进程通讯的解决方案,很是便利。Feathers 中文文档少,使用 Express 和 JWT,偏重实时交互;Egg 由阿里开发,使用 Koa,感受更适合国内的企业应用开发。
实时 web app 使用 Meteor
若是你要开发一个涉及聊天、物联网功能的实时应用,那么 Meteor 和 Feathers 很适合。
构建微服务 REST API 首选 hapi
若是你要开发简单的几个微服务后端,那么 hapi 和 restify 合适。若是是大型的复杂应用,甚至是在现有微服务上构建,那么 LoopBack 多是个好选择,它能够把不少服务 glue 到一块儿。还能够结合 StrongLoop 的 API 网关一块儿使用。
静态网站生成首选 Gatsby,不使用 React 的话用 Hexo。
最后,建议你们选择的时候不要太纠结,差很少就好了。由于在项目开始时不可能想得面面俱到,关键是大的方向,快点出 MVP。根据多年来的经验,一个项目要不是很快夭折,要不就是活到被重写的那一天。用哪个真的不是过重要,赶忙先选一个干起来。