gpt4 book ai didi

javascript - AWS Lambda postgres 连接超时,但仅在第一次尝试时

转载 作者:行者123 更新时间:2023-11-29 14:03:25 30 4
gpt4 key购买 nike

我正在使用 Lambda 连接到属于 VPC 的 Postgres RDS 实例。如果Lambda函数一段时间没有被调用,执行大约2分钟后会出现如下错误:

could not connect to postgres { [Error: connect ETIMEDOUT] code: 'ETIMEDOUT', errno: 'ETIMEDOUT', syscall: 'connect' }

当 lambda 函数重试时,它会成功连接到数据库并正常执行。

Lambda 函数是使用 node-postgres 包为 node.js 编写的。连接程序看起来像这样:

var client = new pg.Client(conString);
client.connect(function(err) {
console.log("client connected");
if(err) {
context.fail('Connection failed');
}
else { //do stuff }
}

日志显示它在超时之前永远不会到达“客户端连接”。在这些第一次尝试中出了什么问题?

注意:如果在 20-30 分钟内再次调用 lambda 函数,则不会发生此超时并且函数会成功执行。

最佳答案

这个问题也发生在我身上,在我第一次尝试调用 lambda 函数时没有使用 lambda 几分钟后,我得到了

{"errorMessage":"connect ETIMEDOUT","errorType":"SequelizeConnectionError","stackTrace":["Handshake._callback (/var/task/node_modules/sequelize/lib/dialects/mysql/connection-manager.js:94:20)","Handshake.Sequence.end (/var/task/node_modules/mysql/lib/protocol/sequences/Sequence.js:96:24)","Protocol.handleNetworkError (/var/task/node_modules/mysql/lib/protocol/Protocol.js:364:14)","Connection._handleNetworkError (/var/task/node_modules/mysql/lib/Connection.js:421:18)","Connection._handleConnectTimeout (/var/task/node_modules/mysql/lib/Connection.js:417:8)","Socket.g (events.js:260:16)","emitNone (events.js:67:13)","Socket.emit (events.js:166:7)","Socket._onTimeout (net.js:318:8)","_runOnTimeout (timers.js:524:11)","_makeTimerTimeout (timers.js:515:3)","Timer.unrefTimeout (timers.js:584:5)"]}

重试 2-3 次后它有效

关于javascript - AWS Lambda postgres 连接超时,但仅在第一次尝试时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36189182/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com