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

  • 相关阅读:
    Jquery的函数
    Jquery的$.ajax()函数$.get(),$.post(),$.getjson(),$.ajax()
    $.ajax()详解
    JSON 数据格式,能比较清晰容易理解的解读json
    练习:WinForm 对话框控件(文件读取、写入)
    练习:WinForm 对话框控件(显示、获取)
    练习:WinForm--DataGridView增删改查完整版
    Chapter 10. WinForm-DataGridView(确认删除、多条件查询、数据区别显示)
    Chapter 10. WinForm-DataGridView
    练习:WinForm 计算器
  • 原文地址:https://www.cnblogs.com/wewe/p/2668052.html
Copyright © 2011-2022 走看看