zoukankan      html  css  js  c++  java
  • [Node.js] Stream all things!

    Node.js come alone with many Stream API. Stream is useful when handling large trunck of data.

    For example, we have a big file to read from file system:

    // create-big-file.js
    
    const fs = require('fs')
    const file = fs.createWriteStream('./big.file')
    
    for (let i = 0; i <= 1e6; i++) {
        file.write('awefawgrga afewfa')
    }
    
    file.end();

    If we are reading it using normal API:

    const fs = require('fs')
    const server = require('http').createServer();
    server.on('request', (req, res) => {
        fs.readFile('./big.file', (err, data) => {
            if (err) throw err;
    
            res.end(data);
        })
    });
    server.listen(8000);

    When running the code, we found that the normal memory cost is 8MB, when reading the large file, memory cost is 400+MB, basiclly it buffer all the file content into the memory, this is not the way we want.

    Using Stream:

    const fs = require('fs')
    const server = require('http').createServer();
    server.on('request', (req, res) => {
        /*fs.readFile('./big.file', (err, data) => {
            if (err) throw err;
    
            res.end(data);
        })*/
        const src = fs.createReadStream('./big.file')
        src.pipe(res)
    });
    
    server.listen(8000);

    After updating the code, the memory usage of stream version stay around 30-40MB.

  • 相关阅读:
    Python 十七天 成员
    python学习17——字典。
    python学习16——列表。
    python学习15——Random。
    python学习14——分支和函数。
    python学习13——while循环。
    python学习12——循环和列表
    python学习8——整理第一部分。
    Flask HTTP请求与响应
    Falsk 路由简析
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10516507.html
Copyright © 2011-2022 走看看