【发布时间】:2016-09-30 01:18:45
【问题描述】:
我正在尝试从 lambda 连接到我的 RDS 实例。我在本地编写了 lambda 并在本地进行了测试,一切都很顺利。我部署到 lambda,突然它不起作用。下面是我正在运行的代码,如果有帮助,我将通过 kinesis 流调用 lambda。
'use strict';
exports.handler = (event, context, handlerCallback) => {
console.log('Recieved request for kinesis events!');
console.log(event);
console.log(context);
const connectionDetails = {
host: RDS_HOST,
port: 5432,
database: RDS_DATABASE,
user: RDS_USER,
password: RDS_PASSWORD
};
const db = require('pg-promise')({promiseLib: require('bluebird')})(connectionDetails);
db
.tx(function () {
console.log('Beginning query');
return this.query("SELECT 'foobar'")
.then(console.log)
.catch(console.log)
.finally(console.log);
})
.finally(() => handlerCallback());
};
如果有帮助,这里是来自 Cloud Watch 的日志:
START RequestId: *********-****-****-****-********* Version: $LATEST
2016-05-31T20:58:25.086Z *********-****-****-****-********* Recieved request for kinesis events!
2016-05-31T20:58:25.087Z *********-****-****-****-********* { Records: [ { kinesis: [Object], eventSource: 'aws:kinesis', eventVersion: '1.0', eventID: 'shardId-000000000000:**********************************', eventName: 'aws:kinesis:record', invokeIdentityArn: 'arn:aws:iam::******************:role/lambda_kinesis_role', awsRegion: 'us-east-1', eventSourceARN: 'arn:aws:kinesis:us-east-1:****************:stream/route-registry' } ] }
2016-05-31T20:58:25.283Z *********-****-****-****-********* { callbackWaitsForEmptyEventLoop: [Getter/Setter], done: [Function], succeed: [Function], fail: [Function], logGroupName: '/aws/lambda/apiGatewayRouteRegistry-development', logStreamName: '2016/05/31/[$LATEST]******************', functionName: 'apiGatewayRouteRegistry-development', memoryLimitInMB: '128', functionVersion: '$LATEST', getRemainingTimeInMillis: [Function], invokeid: '*********-****-****-****-*********', awsRequestId: '*********-****-****-****-*********', invokedFunctionArn: 'arn:aws:lambda:us-east-1:*************:function:apiGatewayRouteRegistry-development' }
END RequestId: *********-****-****-****-*********
REPORT RequestId: *********-****-****-****-********* Duration: 20003.70 ms Billed Duration: 20000 ms Memory Size: 128 MB Max Memory Used: 22 MB
2016-05-31T20:58:45.088Z *********-****-****-****-********* Task timed out after 20.00 seconds
【问题讨论】:
-
您是否为您的 Lambda 函数启用了 VPC 访问?
-
@MarkB 不。我将下拉菜单设置为“无 VPC”
-
那么您在 RDS 实例上启用了可公开访问,并且您已将 RDS 实例的安全组向全世界开放?
-
@MarkB 是的,我可以直接从我的笔记本电脑访问 RDS。整个 lambda 在我的本地机器上运行良好。
-
20 秒似乎足够了,但是如果你将 Lambda 超时时间暂时提高到 60 秒,它会起作用吗?
标签: javascript amazon-web-services amazon-rds aws-lambda amazon-kinesis