http://www.cnblogs.com/sysuys/p/3460614.html

解决方案 »

  1.   

    Node.js好像号称除了代码全都是并发的。要理解Node.js的原理你可能需要了解一些多线程或者并发的基本知识,否则就算解释也有牵强附会的嫌疑,而就算你感觉明白了也不是一种本质上的理解。
      

  2.   

    简单的理解在异步的优势,就是导弹中的发射后用不用管的做法。同步,你去操作IO,IO没有返回,你就在那等着吧,所以同步的程序象apache,就要开很多的进程,专门存放存放这此同步的操作,关键是一整套的操作全在那里挂着耗内存和别的资源呢。
    异步,发送IO操作请求后,你可以去做别的事,IO返回后会自动做下一步的,而且你可以同时发起多个IO然后一起汇总。所以只用单线程就可以了,每一步的操作可以用整体更少的资源满足要求。
      

  3.   

    谢谢详细的指导。
    我关于node.js长处的理解:
    1、node.js通过明确分工的方式,将接收请求和处理请求分开,让接待和生产各司其职。这样就不用维护维护多个连接请求,节约内存,解决需要多开服务器的问题。
    2、通过事件回调机制,自然解决I/O阻塞问题,提高处理速度。
      

  4.   

    那是忽悠人的,或者说是介绍者的“口误”如果是“不用维护维护多个连接请求”,那么处理结束后把结果返回给谁?
    node.js 支持 server push 不维护连接向谁“推”?广播?
      

  5.   

    异步的优势,可以参考ajax,ajax全称是异步的javascript和xml,为什么要异步,HttpRequest是可以同步操作的,但同步时如果HttpRequest没有返回时,浏览器就象给卡住了,什么都动不了。
    同理在服务器端,异步最大的好处就是最大限度的消除了IO等待的问题。不过在多并发的生产环境中,最后系统的瓶颈还是会卡在IO上,nodejs对此帮助有限,所以还是要考虑内存数据之类的方案提高IO性能,开发语言还是按自己喜好和团队优秀合理选择。