与 Postman 一起测试,我会尽量把它说清楚,如果这没有意义,请告知。
我有一个 Lambda,它在 AWS 上使用 MySQL RDS 数据库,并且在访问 AWS 上的数据库时在本地运行良好。从 auth
端点成功获取 JWT 后,我尝试点击 login
端点并得到 502 Bad Gateway
。使用 CloudWatch 日志,我可以在登录查询运行之前跟踪故障。我已经确认我的 MySQL 配置是正确的,并且我已连接到数据库。 lambda 和数据库位于同一区域 DB: us-east-1f
, lambda: us-east-1
。
我已确认此端点的 OPTIONS 和 POST 请求方法均设置为在 API 网关中启用了 CORS。我正在使用 serverless.yml 在所有端点上设置 cors: true
,即使我在索引文件中使用 app.use(cors())
。
502 的错误消息是,{"message": "Internal server error"}
这是我的代码中的失败点:
'use strict';
const mysql = require('./index');
module.exports = {
loginSql: async (email, password) => {
// MAKES IT HERE AND THE PARAMS ARE CORRECT
try {
console.log('IN TRY %%%%%%%%%%%%%%');
// SEEMS TO DIE HERE
const results = await mysql.query({
sql: `SELECT
id, first_name, last_name, email
FROM users
WHERE email = ?
AND password = ?`,
timeout: 50000,
values: [email, password],
});
// NEVER MAKES IT HERE /////////
console.log('QUERY RAN %%%%%%%%%%%%');
mysql.end();
if (results.length < 1) return false;
return results;
} catch (error) {
// DOESN'T THROW ERROR
console.log('LOGIN DB ERROR', error);
throw new Error('LOGIN DB ERROR THROWN', error);
}
},
};
答案 0 :(得分:1)
我刚刚创建了完全相同的用例,因为我有一个用 Java 编写的 LAMBDA 函数,用于从 MySQL RDS 实例查询数据。它完美运行。
这是您的问题:
要从 Lambda 函数连接到 RDS 实例,您必须使用与 RDS 实例相同的安全组设置入站规则。详情请How do I configure a Lambda function to connect to an RDS instance?。