'找不到模块fluent-ffmpeg'在AWS Lambda上

时间:2016-04-02 09:58:06

标签: javascript node.js amazon-web-services aws-lambda

我在AWS Lambda上运行视频处理脚本。

虽然它似乎在本地完美运行(使用lambda-local测试),但我在Lambda上运行时遇到一个奇怪的问题:

{
  "errorMessage": "Cannot find module 'fluent-ffmpeg'",
  "errorType": "Error",
  "stackTrace": [
    "Function.Module._resolveFilename (module.js:338:15)",
    "Function.Module._load (module.js:280:25)",
    "Module.require (module.js:364:17)",
    "require (module.js:380:17)",
    "Object.<anonymous> (/var/task/processing.js:2:14)",
    "Module._compile (module.js:456:26)",
    "Object.Module._extensions..js (module.js:474:10)",
    "Module.load (module.js:356:32)",
    "Function.Module._load (module.js:312:12)",
    "Module.require (module.js:364:17)"
  ]
}

我上传的ZIP包含以下文件:

~$ find . -maxdepth 2
.
./bin
./bin/ffmpeg
./config.js
./event-samples
./event-samples/custom.js
./event-samples/dynamodb-update.js
./event-samples/kinesis.js
./event-samples/s3-put.js
./frames
./Gulpfile.js
./index.js
./node_modules
./node_modules/async
./node_modules/aws-sdk
./node_modules/fluent-ffmpeg
./node_modules/gulp
./node_modules/gulp-awslambda
./node_modules/gulp-zip
./package.json
./processing.js
./utils.js

(有缺陷的需求位于 processing.js

如果我打开ZIP,node_modules/fluent-ffmpeg/*确实存在。

我尝试使用以下方法包含该模块:

  • require("./node_modules/fluent-ffmpeg/index")
  • require(__dirname + "./node_modules/fluent-ffmpeg/index")
  • require(process.env.LAMBDA_TASK_ROOT + "/node_modules/fluent-ffmpeg/index")

但这些都没有解决问题。我还尝试在我的机器上重新安装node和npm rm -rf node_modulesnpm install(以防万一)。

由于Lambda运行节点0.10.36,我也尝试在我的机器上使用此版本来执行npm install,但这也不会改变任何内容。

帮助表示赞赏。

谢谢!

1 个答案:

答案 0 :(得分:1)

解决。我的开发机器运行Windows 7,这显然是造成这个问题的原因......不过会对原因感兴趣。

无论如何,在Linux安装上运行npm install并将代码上传到Lambda就可以了。