【问题标题】:Unable to download S3 video inside Lambda function (Node JS)无法在 Lambda 函数(Node JS)中下载 S3 视频
【发布时间】:2026-02-12 07:10:01
【问题描述】:

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

谢谢,

【问题讨论】:

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


    【解决方案1】:

    代码正在异步运行,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);
    });
    

    【讨论】:

      【解决方案2】:

      writeFile 的调用是异步的,即函数立即“结束”,程序继续执行statSync 调用。将其替换为writeFileSync

      【讨论】: