[英]Cannot find MySQL in NodeJS using AWS Lambda
我有以下代码要执行。 我试过需要 mysql 和 node-mysql ,它们都给我同样的错误:
代码:
var AWS = require("aws-sdk");
var mysql = require("mysql");
exports.handler = (event, context, callback) => {
try {
console.log("GOOD");
}
catch (error) {
context.fail(`Exception: ${error}`)
}
};
错误:
{
"errorMessage": "Cannot find module 'mysql'",
"errorType": "Error",
"stackTrace": [
"Function.Module._load (module.js:417:25)",
"Module.require (module.js:497:17)",
"require (internal/module.js:20:19)",
"Object.<anonymous> (/var/task/index.js:2:13)",
"Module._compile (module.js:570:32)",
"Object.Module._extensions..js (module.js:579:10)",
"Module.load (module.js:487:32)",
"tryModuleLoad (module.js:446:12)",
"Function.Module._load (module.js:438:3)"
]
}
如何使用 lambda 将 mysql 导入节点或使其工作?
哦,所以这预计会发生。
问题在于 AWS Lambda 在不同的机器上运行,您无法配置该特定机器以在自定义环境中运行。 但是,您可以将mysql
或node-mysql
的节点模块打包到 zip 中并上传到 AWS Lambda。 步骤是,
npm install mysql --save
您还可以通过使用无服务器框架采取更好的方法。 更多信息在这里。 在这种方法中,您编写了一个 YAML 文件,其中包含要用于部署 lambda 的所有详细信息和配置。 在您的 lambda 配置下,在package
-> include
部分下指定节点模块的路径(例如, nodemodule/**
)。 这将打包您所需的代码。 稍后使用命令行,您可以部署此 lambda。 它使用 AWS Cloudformation 服务,是部署资源的首选方式之一。
可以在此处找到有关使用无服务器框架进行打包的更多信息。
注意:要使用无服务器框架,有几个步骤,例如为您的用户获取 API 密钥、在 IAM 中设置正确的权限等。这些只是初始设置,以后不需要。 在使用无服务器框架进行部署之前,请务必执行这些操作。
希望这有帮助!
如果任何身体需要替代品,
您可以使用 cloud9 IDE,它可以免费打开 lambda 函数并使用终端窗口对 lambda 函数文件夹执行 npm init 这将提供节点包文件,然后可用于安装依赖项。
如果使用 package.json,只需在下面添加并运行“npm install”
{“依赖项”:{“mysql”:“2.12.0”}}
我在使用knex时遇到了这种情况,尽管我的 package.json 中有mysql
。
我必须在我的 lambda(或它引用的文件require('mysql')
中require('mysql')
,以便无服务器在部署期间对其进行打包。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.