流是Nodejs的高级应用,掌握流的使用,才能真正胜任NodeJS开发。

Nodejs中,流是基于事件的API,用于管理和处理数据,而且效率很好!

什么是流?

流是一个抽象接口,Node 中有很多对象实现了这个接口。

例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出)等。

流的四种类型

dable - 可读操作。

Writable - 可写操作。

Duplex - 可读可写操作.

Transform - 操作被写入数据,然后读出结果。

流的事件

所有的流对象都是 EventEmitter 的实例,流常用的事件有:

data - 当有数据可读时触发。

end - 没有更多的数据可读时触发。

error - 在接收和写入过程中发生错误时触发。

finish - 所有数据已被写入到底层系统时触发。

什么时候使用流?

举例说明:

1、当使用fs.readFileSync同步读取一个文件的时候,所有的数据会被全部读到内存中,这个操作过程中程序会被阻塞。

2、如果使用fs.readFile,由于它是异步方法,那么阻塞不会发生,但数据仍会被全部读到内存中再处理。

当处理大文件压缩、媒体文件等的时候,无疑会很吃力。那么这时,就是使用流的时候了。

3、流会将分批次的读取适量的内容到缓存区进行操作,而不是一次性读取所有目标内容。

这样,程序对内存的使用量会极大减少、执行性能会提升很多:

举例说明,使用流的优势

先使用node内置的核心模块http实现一个简单的静态web服务器:

var http = require("http");
var fs = require("fs");

http.createServer(function(req,res){
    fs.readFile(__dirname + "/test10.js",function(err,data){
        if(err){
            res.statusCode = 500;
            res.end(String(err));
        }else{
            res.end(data);
        }
    })
}).listen(8000);

这段代码使用非阻塞的fs.readfile的方法。

当被访问时,读取文件内容(代码中读取的是本举程代码)并发送给访问者。

测试访问,效果:

可能说,功能并无问题。但如果被读取的文件test10.js文件非常大呢。就会有效率问题。

这时,可以改用流的方式:

注意图中标识出的内容,是修改的内容:使用流的方式读取,通过管道(pipe)传给res。

var http = require("http");
var fs = require("fs");

http.createServer(function(req,res){

    fs.createReadStream(__dirname+"/test10.js").pipe(res);

}).listen(8000);

执行效果一样,但对内存的使用得到优化,性能得到提升。

同时,代码也更简洁。

流不仅高效优雅,扩展性也更强。比如对上面的代码稍做改动,就可以实现gzip压缩传输数据,可以使网页打开更快。

var http = require("http");
var fs = require("fs");
var zlib = require("zlib");

http.createServer(function(req,res){

    res.writeHead(200,{"content-encoding":"gzip"});

    fs.createReadStream(__dirname+"/test10.js").pipe( zlib.createGzip() ).pipe(res);

}).listen(8000);

从浏览器信息中可以看到,内容已启用gzip压缩。

Node.js实战10:“流”是Node.js最强大的功能之一。的更多相关文章

  1. Node.js实战(四)之调试Node.js

    当项目逐渐扩大以后,功能越来越多,这时有的时候需要增加或者修改,同时优化某些功能,就有可能出问题了.针对于线上Linux环境我们应该如何调试项目呢? 别怕,Node.js已经为我们考虑到了. 通过 n ...

  2. [Node.js] Node.js中的流

    原文地址:http://www.moye.me/2015/03/29/streaming_in_node/ 什么是流? 说到流,就涉及到一个*nix的概念:管道——在*nix中,流在Shell中被实现 ...

  3. 10个最佳Node.js企业应用案例:从Uber到LinkedIn

    译者按: Node.js 8已经发布了,NPM模块每周下载量早已超过10亿,从Uber到LinkedIn都在使用Node.js,谁说JavaScript不能写后台? - 原文: 10 best Nod ...

  4. 《Node.js实战(双色)》作者之一——吴中骅访谈录

  5. Node.js v0.10.31API手冊-控制台

    Node.js v0.10.31API手冊-文件夹 控制台 Object 用于向 stdout 和 stderr 打印字符.类似于大部分 Web 浏览器提供的 console 对象函数,在这里则是输出 ...

  6. Node.js v0.10.31API手冊-事件

    Node.js v0.10.31API手冊-文件夹 Events(事件) Node里面的很多对象都会分发事件:一个net.Server对象会在每次有新连接时分发一个事件, 一个fs.readStrea ...

  7. Node.js v0.10.31API手工-DNS

    原版的API品种,这是从以前的翻译和翻译风格不同 Node.js v0.10.31API手冊-文件夹 DNS 使用 require('dns') 引入此模块. dns 模块中的全部方法都使用了 C-A ...

  8. iKcamp团队制作|基于Koa2搭建Node.js实战项目教学(含视频)☞ 环境准备

    安装搭建项目的开发环境 视频地址:https://www.cctalk.com/v/15114357764004 文章 Koa 起手 - 环境准备 由于 koa2 已经开始使用 async/await ...

  9. Node.js实战项目学习系列(1) 初识Node.js

    前言 一直想好好学习node.js都是半途而废的状态,这次沉下心来,想好好的学习下node.js.打算写一个系列的文章大概10几篇文章,会一直以实际案例作为贯穿的学习. 什么是node Node.js ...

随机推荐

  1. Linux架构之Nginx 七层负载均衡

    第50章 Nginx七层负载均衡 一.Nginx负载均衡基本概述 1)为什么要使用负载均衡 当我们的Web服务器直接面向用户,往往要承载大量并发请求,单台服务器难以负荷.使用多台Web服务器组成集群, ...

  2. <authentication> 元素

    <authentication> 元素 配置 ASP.NET 身份验证支持.该元素只能在计算机.站点或应用程序级别声明.如果试图在配置文件中的子目录或页级别上进行声明,则将产生分析器错误信 ...

  3. DevExpress v19.1新版亮点——WinForms篇(三)

    行业领先的.NET界面控件DevExpress v19.1终于正式发布,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WinForms v19.1中新增的一些控 ...

  4. Arduino-数学函数

  5. 部署至Oracle数据库的注意事项

    部署至Oracle数据库的注意事项 安装数据库之前1)检查计算机名,如果是乱码,改一下名字 2)有杀毒软件,能关则关               但是最好征求用户的同意 3)装两个一起解压databa ...

  6. 三、angular7登录请求和路由带参传递

    在 app.module.ts 中引入 HttpClientModule 并注入 import {HttpClientModule} from '@angular/common/http'; impo ...

  7. (12)QT中搭建opencv开发环境

    只需要在项目工程文件pro中添加上: INCLUDEPATH += G:/opencv/build/include \ G:/opencv/build/include/opencv \ G:/open ...

  8. Twice Equation

    题目链接:https://nanti.jisuanke.com/t/A1541 题意:给你一个L,要你求一个不小于L的最小数字n,对于一个整数m,满足2*(m+1)*m=n*(n+1). 思路:打表找 ...

  9. permutation 2

    permutation 2 猜了发结论过了== $N$个数的全排列,$p_{1}=x,p_{2}=y$要求$|p_{i+1}-p_{i}|<=2|$求满足条件的排列个数. 首先考虑$x=1,y= ...

  10. [ethereum源码分析](5) 创建新账号

    前言 在上一章我们介绍了 ethereum运行开启console 的过程,那么在这一章我们将会介绍如何在以太坊中创建一个新的账号.以下的理解可能存在错误,如果各位大虾发现错误,还望指正. 指令分析 指 ...