无法在Lambda函数(Node JS)中下载S3视频

时间:2019-02-03 17:45:24

标签: amazon-web-services amazon-s3 aws-lambda fs

我正在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存储中下载此文件后,我必须将此视频文件转换为音频文件。因此,请帮助我找出解决方案。

谢谢

2 个答案:

答案 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