我正在Lambda函数中尝试从S3下载视频文件。这个想法是,只要将视频文件上传到S3存储桶中,lambda函数就会被触发。在Lambda函数中,我正在下载视频文件并将其存储在/ tmp / storage中。
这是我的代码,
const fs = require('fs');
const AWS = require('aws-sdk');
const s3 = new AWS.S3();
exports.handler = function (event, context, callback) {
var params = {
Bucket: "Bucket_name",
Key: event.Records[0].s3.object.key
}
console.log("key ", event.Records[0].s3.object.key);
s3.getObject(params, function(err, data){ if (err) {
console.error(err.code, "-", err.message);
return callback(err);
}
fs.writeFile("/tmp/vid.mp4", data.Body, function(err){
if(err)
console.log(err.code, "-", err.message);
return callback(err);
});
var stats = fs.statSync("/tmp/vid.mp4");
console.log("size of the file ", stats["size"]);
});
};
但是执行此lambda函数时没有出现任何错误。但是,当我检查文件的大小时,它的值为0 。我对如何解决这个问题一无所知。在lambda tmp存储中下载此文件后,我必须将此视频文件转换为音频文件。因此,请帮助我找出解决方案。
谢谢
答案 0 :(得分:0)
代码异步运行,console.log
的文件大小在writeFile
完成之前执行。您需要将statSync
放在writeFile
回调中:
fs.writeFile("/tmp/vid.mp4", data.Body, function(err){
if(err) console.log(err.code, "-", err.message);
var stats = fs.statSync("/tmp/vid.mp4");
console.log("size of the file ", stats["size"]);
return callback(err);
});
答案 1 :(得分:0)
对writeFile
的调用是异步的,即,函数立即“结束”,并且通过statSync
调用继续执行程序。将其替换为writeFileSync
。