使用 Node.js 的优势和劣势都有哪些?

有大公司用吗?
关注者
4,433
被浏览
812,346

54 个回答

我们在用 Node.js 处理知乎主站的 web 实时推送。你现在看到的 Feed 、消息的实时更新,背后就是几个 node 进程扛起来的。

优点:

1. 处理高并发场景性能更高

在用 socket.io 之前,推送服务是用 ajax polling 做的。我们用 Tornado 和 Node.js 做过两个版本的推送服务。在当时的测试环境下,Node.js 的 CPU 时间是 Tornado 的三分之一,内存使用是 Tornado 的一半,代码行数只有 Tornado 的三分之一(Node.js 版是用 coffee 写的)。后来我们使用了 socket.io,CPU 开销进一步降低。

2. 函数式编程非常适合写异步回调链

用 Node.js 配合 CoffeeScript 写异步操作链非常便利,相比之下 Tornado 无论是写命名函数的回调,还是 yield 一个 Task 都没那么自然。

缺点:

1. 大量匿名函数使异常栈变得不好看。

2. 无法以 request 为单位 catch 异常,必须确保不要在不 catch 异常的第三方库的回调里的抛异常,这在一个异步操作链条里是一件比较麻烦的事。解决方法之一是对那些不 catch 异常的第三方库做一些封装,把所有的异常变成事件,改成 on('error') 形式的 API。

我用 Node.js 开发了 Am I Hacked,算是有一点用 Node.js 支持大流量的经验。先列一些数字

  • 服务器是 Linode 512,也就是 Linode 上最低端的 VPS ,只有 512MB 的内存。
  • 数据库,Node.js 程序和静态文件都放在同一台服务器上。
  • 大部分查询耗时 20-100ms 。少数查询由于缓存 miss 较多,耗时会高达500ms。
  • 最高日PV超过了一百万,Google Analytic 上显示的同时在线人数最高达2000。
  • 平均每秒能完成20-30次查询,瓶颈在磁盘IO,CPU几乎无压力。
  • 虽然压力如此之大,首页几乎都能在一秒内打开,查询也会在3秒内返回。
  • Node.js 程序占用内存 90MB-110MB,剩余内存都被磁盘缓存占据。

以我的了解,Python 和 Ruby 上的非 Event Driven 的 Framework 根本不可能达到这样的性能。

然后说说 Node.js 的其他优点

  • Node.js 的架构与 Django, Rails 等传统的 Framework 不同,不需要放在 Nginx / Apache 后,利用 WSGI, CGI 之类的接口一板一眼的 [接受Request] -> [运行程序逻辑] -> [生成并返回Response]。这是一个巨大的变化,之前一些无法想象的功能都有可能实现了。比如 github.com/Miserlou/Dir 可以用浏览器实现 P2P 的文件传输。正因为 Node.js 可以更精细的控制 Request 和 Response 的时间和内容,websocket 似乎天生就是为 Node.js 而生的,而配合 socket.io 这个神奇的库之后,在 realtime webapp 这个领域,Node.js 已经没有对手了。
  • Node.js 的包管理器 npm 设计得比 python 和 ruby 好很多。有很多的 module 开发者。

当然也有一些缺点

  • Debug 很困难。没有 stack trace,出了问题很难查找问题的原因。
  • 如果设计不好,很容易让代码充满 callback 。实在受不了的可以考虑一下 github.com/laverdet/nod 这个项目。不过 Node.js 的核心团队并不推荐使用。

有没有大公司使用?

  • LinkedIn Mobile 的 服务器端完全是用 Node.js 写的。
  • Yahoo 有一部分新项目使用了 Node.js。
  • 阿里巴巴内部也有一些新项目用到了 Node.js。