zoukankan      html  css  js  c++  java
  • [笔记]使用 NodeJS Stream 的一个例子

    使用NodeJS Stream的一个例子

    1 what is stream ?

    流(stream)的概念来自unix。流的思想让do one thing well的小的功能块构建庞大的系统。

    shell中使用管道符号 | 来实现流操作

    node中也有相应的流操作模块

    2 为什么要使用stream呢?

    {原文}why you should use streams

    一个简单的http文件服务器

    var http = require('http');
    var fs = require('fs');
    
    var server = http.createServer(function (req, res) {
        fs.readFile(__dirname + '/data.txt', function (err, data) {
            if (err) {
                res.statusCode = 500;
                res.end(String(err));
            }
            else res.end(data);
        });
    });
    server.listen(8000);
    

    改用stream的方式

    var http = require('http');
    var fs = require('fs');
    
    var server = http.createServer(function (req, res) {
        var stream = fs.createReadStream(__dirname + '/data.txt');
        stream.on('error', function (err) {
            res.statusCode = 500;
            res.end(String(err));
        });
        stream.pipe(res);
    });
    server.listen(8000);
    

    好处是什么呢?

    • 代码更清晰
    • 避免回调嵌套
    • 每次读取到一个数据段chunk,就会立刻将数据发往客户端 ,所以,node不必将完整的文件数据载入内存

    改进后的代码,若还嫌长的啰嗦,有一个库可供使用

    var http = require('http');
    var filed = require('filed');
    
    var server = http.createServer(function (req, res) {
        filed(__dirname + '/data.txt').pipe(res);
    });
    server.listen(8000);
    

    filed 模块 提供mime types ,etag 缓存,错误处理支持

    压缩响应内容,使用oppressor

    var http = require('http');
    var filed = require('filed');
    var oppressor = require('oppressor');
    
    var server = http.createServer(function (req, res) {
        filed(__dirname + '/data.txt')
            .pipe(oppressor(req))
            .pipe(res)
        ;
    });
    server.listen(8000);
    

    Author: tom

    Date: 2012-09-02 23:02:49 CST

    HTML generated by org-mode 6.33x in emacs 23

  • 相关阅读:
    vue学习目录
    充分利用 SQL Server Reporting Services 图表
    MSCRM 用户登录日志
    Microsoft Dynamics CRM MVP
    在SSRS 里实现 SUMIF
    MSCRM 报表显示 rsprocessingaborted 错误
    电商CRM的痛点在哪里?
    MSCRM 2011/2013/2015 修改显示记录数
    MSCRM 2013/2015 Ribbon Editor
    Q:解决每天第一次打开MSCRM系统展示慢的问题
  • 原文地址:https://www.cnblogs.com/wewe/p/2668052.html
Copyright © 2011-2022 走看看