[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.
分类:
Node.js
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2018-03-12 [HTML 5] More about ARIA Relationships
2018-03-12 [HTML5] aria-label & aria-labelledby
2018-03-12 [HTML5] Why ARIA?
2018-03-12 [React] How to use a setState Updater Function with a Reducer Pattern
2017-03-12 [Recompose] When nesting affects Style
2016-03-12 [RxJS] Refactoring CombineLatest to WithLatestFrom