我正在使用 Node.js .10.22 和 q-fs
我正在尝试将对象上传到 S3,但一旦对象超过特定 MB 大小,S3 就会停止工作。
除了占用我机器上的所有内存之外,它还给我这个错误
RangeError: length > kMaxLength
at new Buffer (buffer.js:194:21)
当我尝试在文件上使用 fs.read
时。
通常,当它起作用时,我会执行s3.upload
,并将缓冲区放入Body
字段中。
如何处理大型物体?
最佳答案
您需要使用 API 的流式传输版本将您的可读文件系统流直接通过管道传输到您正在使用的 s3 模块提供的 S3 上传 http 请求正文流。这是直接来自 aws-sdk documentation 的示例
var fs = require('fs');
var body = fs.createReadStream('bigfile');
var s3obj = new AWS.S3({params: {Bucket: 'myBucket', Key: 'myKey'}});
s3obj.upload({Body: body}).
on('httpUploadProgress', function(evt) { console.log(evt); }).
send(function(err, data) { console.log(err, data) });
关于node.js - 如何读取大文件并将其上传到 s3?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29709182/