使用流处理大文件可避免内存溢出。1. 上传时用multer分块暂存,再通过fs.createReadStream读取并pipe到目标文件,最后删除临时文件;2. 下载时用fs.createReadStream创建读取流,设置响应头后pipe到res,实现分批传输;3. 增强稳定性需监听error事件,及时销毁流并释放资源。

处理大文件上传与下载时,直接读取整个文件到内存会导致内存溢出。Node.js 的流(Stream)机制能有效解决这个问题,通过分块传输数据,实现高效、低内存占用的文件操作。
前端上传大文件时,后端应避免一次性加载整个文件。利用 multer 中间件配合流式写入,可将文件分块保存到磁盘。
安装 multer:
npm install multer示例代码:
const express = require('express');说明:multer 将文件暂存本地,再通过可读流读取并用 pipe 导入可写流,逐块写入目标位置,避免内存压力。
用户请求下载大文件时,不应使用 fs.readFile,而应创建可读流,通过 pipe 发送给响应对象。
示例代码:
app.get('/download/:filename', (req, res) => {说明:设置合适的响应头后,将文件流通过 pipe 接入 HTTP 响应,数据分批发送,不占内存。
在实际应用中,需考虑错误处理和资源释放,确保服务健壮。
增强版下载示例:
readStream.on('error', (err) => {基本上就这些。用流处理大文件,核心是避免内存堆积,借助 pipe 实现高效管道传输,上传下载都能稳定运行。
以上就是如何用Node.js流处理大文件上传与下载?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号