《7月份读书活动 - 深入显出Node.js》

《7月份读书活动 - 深入浅出Node.js》

 

    前言

 

        赶在最后一天,再忙还是要参加一下社区的活动~

 

    正文

 

        其实自己从事node相关的开发已经有一段时间了,看了本书后,发现有一些理论的内容还是有待提高,按照自己的一些理解,从中抽取了一些比较有意义的内容:

 

      Node的特点:

 

     要学习和使用一个新技术,知道它的特点还是有必要的

 

  • 异步I/O

     一般作为前端,用的比较多的就是ajax,在node里面,于此方式类似的就是文件操作。

 

     异步I/O在文件读取这种任务里面,充分体现了效率编程的优势,相比同步的化,耗时就是几个任务的和。

 

  • 事件与回调函数
  • 单线程

     弱点:

 

  1. 无法利用多核的CPU
  2. 错误会引起整个应用退出
  3. 大量计算占用CPU

       Node采用 child_process,子进程 

 

  • 跨平台

     Node的C++模块也可以借助libuv实现跨平台

 

 

     关于内存相关:

 

     其实到很长一段时间,对应内存相关,自己都没有太多的研究,看了第5章,还是有很多大的收获:

 

  • V8的垃圾回收机制:
  1.  基于分代垃圾回收机制
  2.  V8的内存分代:新生代【存活时间较短】和老生代【存活时间较长或常驻内存的对象】
  3.  V8堆

       整体大小是 新生代 +  老生代

 

       注释:新生代基本哦都是比较小的内存空间

 

  •  web服务场景:通过内存来存储,有可能大量的PV的时候出现内存溢出
  • 如何查看垃圾回收日志:

 

node --trace_gc -e "var a = [];for (var i = 0; i < 1000000; i++) a.push(new Array(100));" > gc.log

 

 

 

     后面也介绍了几个比较有用的命令:

 

  • 进程的内存使用
//进程的内存占用情况
process.memoryUsage();

 

 

  • 系统的内存占用

    核心模块里面的os的两个方法:

 

    下面都是字节单位

 

os.totalmem();   //总内存
os.freemem();    //闲置内存