这段时间nodejs在国内发展是相当迅速的。这门语言“非阻塞,异步,事件驱动”的特点使其非常适合用于高并发量的web服务中。但正所谓“人无完人”,虽然nodejs有很多优点,但依然存在一些问题和缺陷。了解一门语言的优点很重要,但了解它的局限,并在现实开发中尽量规避,更加重要。

       一. 内存限制 

      nodejs是基于google的v8引擎 ,而v8对单个node实例做了内存限制,在32位的系统中默认限制为512m,在64位的系统中则是1g。在游览器端,javascript有1G的内存肯定够了,但在web服务器端,1G就可能不够。以1G为例,每个连接都要占用100M的内存,这样服务最多只能建立10个连接,这显然是不行的。

     据说nodeje为我们提供了一个执行参数用来改变这一个限制,执行语句:    

node test.js –max-old-space-size=1000

     但这样仍然是有限制的,32位是1g,64位为1.7g。

     

     解决方案:

    1. 开始更多nodejs进程

    2. 限制连接数

  3. 使用buffer。比如:http://zheye.org/asks/4da05d30fd503c24f9000001

 

    二.GC(垃圾回收) 

      和java一样,nodejs的V8引擎是有系统进行垃圾回收的,而这是程序员所无法控制的,程序员只能标志这个对象不再使用(obj=null),使得下次gc回收该对象的内存。更加可怕地是,v8在进行gc时,nodejs程序会暂停运行,这时向该程序发起的请求都会被忽略掉,造成服务不能访问。

    解决方案:

     1. 写程序时尽量复用对象,而不是新生成对象。