Node.js不是银弹,但它仍然是颗子弹

fmms 12年前
     <div id="news_body">     <p>        [本文英文原文链接:<a href="/misc/goto?guid=4958330240795928071">Node.js isn't a silver bullet, but it's still a bullet.</a> ]</p>     <p style="text-align:center;"><img title="本文的作者 Craig" alt="Node.js不是银弹,但它仍然是颗子弹" src="https://simg.open-open.com/show/0eac4c1d1a0b9194ed5dc798546e24a6.jpg" width="150" height="150" /></p>     <p style="text-align:center;">本文的作者 Craig</p>     <p>        <strong>本文的作者 <a href="/misc/goto?guid=4958330241771765885" target="_blank">Craig</a> 是一个住在纽约的自由软件开发者,他在最近的看到了一篇名为《<a href="/misc/goto?guid=4958330242581669363" target="_blank">如果你正在使用 Node.js,你就是误入歧途</a>》的文章,文章对 Node.js 横加指责,Craig 对此表示不满,于是写下了下面的文章:</strong></p>     <p>        我真的不知道为什么有人这样的讨厌 Node.js。你也看见了网上有大量关于 Node.js 的文章和高调的言论,就好象 Node.js 是解决所有问题的良方。不是的。就像现有的很多其它框架和语言一样,它在某些事情上表现的很优良,而在其它事情上却很差。</p>     <p>        Node.js,单从我的理解上讲,它的设计目标是更好的通过网络快速、实时的传输少量字节信息。服务器端事件处理,即时消息应用,实时游戏,以及协作工具,这都是可以使用它的很好的例子。拿 <a href="/misc/goto?guid=4958330243377773977" target="_blank">Trello</a> 做个例子。Trello 是一个实时协作应用程序,使用 Socket.io 和 Node.js 来实现客户端之间的实时事件传播和状态变换。你可以使用频繁的探询或用 ajax 长周期探询来完成相同的事情,但这两种方法在服务器端占用了不必要的 worker 线程,需要处理额外的请求。Node.js 从某方面讲,本质上正是<em>擅长</em>做这类事情。它的异步事件处理为基础的架构使得接收、处理、发送实时事件消息变得简单,容易,而且非常有速度。</p>     <p style="text-align:center;"><img title="node.js logo" alt="Node.js不是银弹,但它仍然是颗子弹" src="https://simg.open-open.com/show/2451bb3eac083ae60dc46abe11b8d0c9.jpg" width="245" height="66" /></p>     <p>        可同时,Node.js 不是、不是特别的擅长做计算。比如,如果你想做一个能返回斐波那契数列(Fibonacci)序列中第n个数的 API,用 Node.js 必然不是一个很好的选择,为什么?所有的原因都在于,人们之所以要使用 Node.js 都是为了一个避免去等待什么事情。相比等待一个数据库返回查询结果,Node.js 的做法是触发一个查询动作,设置一个回调事件。这样,当查询在执行时,你的程序可以去做其它事情(比如处理其它请求)。这使得 Node.js 看起来非常的快,通常不需要使用多个 CPU。然而,在我们的这个计算斐波那契数列的例子中,程序不需要去等待<em>任何事情</em>。这个 API 返回结果的速度直接依赖于计算的速度。所以,如果用另外一种计算能力更强的语言,比如 Haskell 或 Scala,更合适。</p>     <p>        所有的这些说明了什么观点?观点就是,如果一个框架只是为了解决任务A而设计,而你却抱怨它不能很好的完成任务B,这是愚蠢而荒谬的。Node.js 在它被设计去做的事情上表现的异常优秀——所以,就不要去嚷嚷它不擅长做其它事情了。</p>     <div id="come_from">      来自:      <a id="link_source2" href="/misc/goto?guid=4958330244168040569" target="_blank">外刊IT评论</a>     </div>    </div>