node.js - AWS lambda 函数错误 - 无法导入模块“索引”:错误
问题描述
我正在尝试在 nodejs 中创建一个 lambda。按照文档,我创建了一个带有 lambda 函数、node_modules 和 package.json 的 zip 文件。我的 lambda zip 文件的结构如下:
my-lambda-function/
|
|---util/
| |
| |--util-1.js
| |--util-2.js
|---api/
| |
| |--api-call-1.js
| |--api-call-2.js
|
|---config
| |
| |--env/
| | |--env-file-1.js
| |
| |--config-file-1.js
| |--config-file-2.js
|
|---node_modules/
| |
| |--module-1/
| |--module-2/
|---index.js
|---package.json
为了创建这个 zip 文件,我正在使用 gulp 任务,
gulp.task('zip', ['test'], () => {
const buildArtifact = ['index.js', 'package.json', 'util/**',
'config/**', 'api/**'];
Object.keys(pjson.dependencies).forEach((dep) => {
buildArtifact.push(`node_modules/${dep}/**/*`);
});
const zipFile = `${pjson.name}.zip`;
return gulp.src(buildArtifact, { base: '.' })
.pipe(zip(zipFile))
.pipe(gulp.dest('build'));
});
此 lambda 使用 lambda-local 在本地运行。但是在测试这个 lambda 时抛出错误
Unable to import module 'index': Error
at Function.Module._resolveFilename (module.js:547:15)
at Function.Module._load (module.js:474:25)
at Module.require (module.js:596:17)
at require (internal/module.js:11:18)
at Object.<anonymous> (/var/task/node_modules/ioredis/built/utils/lodash.js:2:19)
at Module._compile (module.js:652:30)
at Object.Module._extensions..js (module.js:663:10)
at Module.load (module.js:565:32)
当前错误指向 ioredis 模块(在 node_modues 文件夹中可用),但是如果我从代码中删除了 ioredis 的使用(通过删除 ioredis 的导入),则错误将更改为另一个节点模块。
看来我的 lambda 函数无法加载/找到 node_modules。是因为 lambda 无法安装 npm 吗?
解决此问题的任何指示都会有所帮助,因为我们已经为此苦苦挣扎了几天
谢谢
更多细节
- 我们可以通过删除 node_modules 文件夹然后在本地运行 lambda 来重现错误
- 如果我删除所有依赖项,一个简单的日志记录语句将起作用。
- lambda 在 aws 中使用节点 8.10
回答(@Kannaiyan)
将 zip 任务更改为:
gulp.task('npm-install', () => gulp.src('./package.json')
.pipe(gulp.dest('build/'))
.pipe(install({ production: true })));
为我工作。
解决方案
无法导入模块“索引”:错误
看起来您的一些依赖项已安装/未正确打包。删除 node_modules 目录并重新安装模块npm install
应该可以解决问题。
确保按照文档https://docs.aws.amazon.com/lambda/latest/dg/nodejs-create-deployment-pkg.html中的说明打包您的函数
如果你的包错过了一个 node_module,那么它将导致这个错误。
编辑1:
您遇到了 gulp 包装的问题。
以下示例包含使用 gulp 打包 lambda 的完整文档。
https://medium.com/@AdamRNeary/a-gulp-workflow-for-amazon-lambda-61c2afd723b6
希望能帮助到你。