繁体   English   中英

AWS Lambda - 访问公共 AWS RDS MySQL

[英]AWS Lambda - Access Public AWS RDS MySQL

我正在尝试访问公共 AWS RDS mysql,它是公开可用的,我可以从 JetBrains DataGrip IDE 访问数据库,下面是来自 AWS RDS 控制台的配置:

RDS配置

当使用下面的 AWS lambda 函数时(也尝试在没有池的情况下以及在每次执行时创建和结束连接),输出没有给我任何错误。 唯一的输出是池对象...

还有其他人有类似的问题吗? 有没有办法获得更多的错误信息?

我知道 AWS 已经宣布他们将为 VPS 等添加 Lambda RDS 集成,但在那之前没有其他选择吗?

var mysql = require('mysql');
var pool = mysql.createPool({
connectionLimit: 10,
host: 'test.XXXXXXX.us-east-1.rds.amazonaws.com',
port: 3306,
user: 'user',
password: 'password',
database: 'theDB'
});

function execute(event, context) {

console.log(pool);
pool.getConnection(function (err, connection) {
    if (err) {
        console.error('error connecting: ' + err.stack);
        context.fail(err);
    } else {
        console.log('connected as id ' + connection.threadId);
        console.log("connect to db!!!!");

    }
    console.log(connection);
    connection.query('SELECT * FROM table', function (err, results, fields) {
        if (err) {
            context.fail(err);
        } else {
            console.log(results);
            console.log(fields);
            console.log("Select Done");
        }
    });
    connection.release();
});

context.done(null, null);

};

exports.handler = execute;

context.done()应该在pool.getConnection(function (err, connection) {...})中。

pool.getConnection()是一种异步方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM