节点 Lambda:MySQL 查询永远不会运行

时间:2021-02-06 21:40:17

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

与 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);
    }
  },
};

1 个答案:

答案 0 :(得分:1)

我刚刚创建了完全相同的用例,因为我有一个用 Java 编写的 LAMBDA 函数,用于从 MySQL RDS 实例查询数据。它完美运行。

这是您的问题:

要从 Lambda 函数连接到 RDS 实例,您必须使用与 RDS 实例相同的安全组设置入站规则。详情请How do I configure a Lambda function to connect to an RDS instance?

enter image description here