首页 > 解决方案 > 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 吗?

解决此问题的任何指示都会有所帮助,因为我们已经为此苦苦挣扎了几天

谢谢

更多细节

  1. 我们可以通过删除 node_modules 文件夹然后在本地运行 lambda 来重现错误
  2. 如果我删除所有依赖项,一个简单的日志记录语句将起作用。
  3. lambda 在 aws 中使用节点 8.10

回答(@Kannaiyan)

将 zip 任务更改为:

gulp.task('npm-install', () => gulp.src('./package.json')
  .pipe(gulp.dest('build/'))
  .pipe(install({ production: true })));

为我工作。

标签: node.jsamazon-web-servicesaws-lambda

解决方案


无法导入模块“索引”:错误

看起来您的一些依赖项已安装/未正确打包。删除 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

希望能帮助到你。


推荐阅读