OSI七层网络模型 | TCP/IP四层概念模型 | 对应网络协议 |
---|---|---|
应用层 | – | – |
表示层 | – | – |
会话层 | – | – |
传输层 | 传输层 | – |
网络层 | 网络层 | – |
数据链路层 | ||
物理层 | ||
node的底层语言是c++; | ||
node是为了高效I/O而生。 | ||
node使用的引擎与js一样。 | ||
node也是单线程的。 | ||
1.node 为什么高效? |
(1)异步I/O
1、单线程阻塞执行 效率低,当读取文件过多导致效率低
2、多线程同步执行 管理复杂 开销太大(占资源)
node所有的异步操作都是通过回调函数的方式。(容易造成回调地狱)
2.各种异步编程方式
3.利用async和promise封装node的异步操作
64位v8引擎分配1.4G内存 32位分配 0.7G内存
新生代内存:
64:64MB 32:
老生代内存:
64:1400MB 32:
node 的核心模块:
1.网络模块 (作为客户端,作为服务端)
2.文件操作
3.事件系统
为什么会有buffer?
node中要用到网络i/o,文件传输 (都是二进制的数据)。
buffer用于存储二进制数据。
buffer是网络传输的基础。
buffer是用的c++的内存,v8来管理。
process.memoryUsage()命令可以查看内存使用情况。
{ rss: 21884928,
heapTotal: 9682944,
heapUsed: 5390872,
external: 16903 }(C++分配的额外内存)。
strem
strem 其实就是一个buffer的高阶封装
strem 有Readable,Writable,Duplex,Transform
strem对象是eventemitter的实例,所以它也可以监听如data,end,error,finish
流是可恢复可缓存的,比如下载
drain事件 缓存区释放后出发 buffer先往内存里写入数据 然后再从内存将数据输出到文件中
pipe 管道 可以直接把读流读入到写流。可以链式调用。
rs.pipe(z.createGzip()).pipe(ws);
将读流通过转换流转换成压缩文件再写入文件。