Node -- 内存控制

在一般的后端语言中是没有内存使用限制的,但是Node中通过JS使用内存时智能使用部分内存,64bit=>1.4G,32bit=>0.7G,所以Node无法直接操作大内存对象,之所以会有这种现象,是因为Node是基于V8引擎构建,V8对于JS对象是通过自己的方式来分配和管理的。至于V8为何要限制内存,其实是出于两方面考虑的一是当时V8面向的是浏览器,大量内存的使用场景很少,二是垃圾回收机制的限制。当然这个限制可以设置。

process.memoryUsege() 查看内存使用情况。

1. 内存相关参数整理

node 启动时添加

--max-old-space-size 新生代空间
--max-new-space-size 老生代空间
--trace_gc -e 垃圾回收日志

2. 大内存的应用

// method1
var reader = fs.createReadStream('in.txt');
var writer = fs.createWriteStream('out.txt');
reader.on('data', function(chunk){
    writer.write(chunk);
}
reader.on('end', function(){
    writer.end();
}

// method2
var reader = fs.createReadStream('in.txt');
var writer = fs.createWriteStream('out.txt');
reader.pipe(writer);

总结: 内存在Node中的使用不是随心所欲的,但也不是完全不擅长,应该时刻注意资源不释放,内存泄漏,scope不明确等问题,特别是在exports和闭包的时候。如果需要用内存做缓存尽量使用内存数据库RedisMemcached

猜你喜欢

转载自blog.csdn.net/castm/article/details/81114336