gpt4 book ai didi

mysql - 使用 Serverless Aurora 时 Sequelize 连接超时,寻找增加超时持续时间或重试连接的方法

转载 作者:可可西里 更新时间:2023-11-01 06:41:44 34 4
gpt4 key购买 nike

我在尝试将无服务器 Aurora 数据库用作我的应用程序的一部分时遇到问题。

问题本质上是当数据库很冷时,建立连接的时间可能大于 30 秒(由于 db spinup)——这似乎比 Sequelize(使用 mysql)中的默认超时时间长,并且作为据我所知,我找不到任何其他方法来增加此超时,或者我可能需要某种重新尝试连接的方法?

这是我当前的配置:

const sequelize = new Sequelize(DATABASE, DB_USER, DB_PASSWORD, {
host: DB_ENDPOINT,
dialect: "mysql",
operatorsAliases: false,
pool: {
max: 2,
min: 0,
acquire: 120000, // This needs to be fairly high to account for a
serverless db spinup
idle: 120000,
evict: 120000
}
});

一些额外的要点:一旦数据库变暖,那么一切都会完美运行。保持数据库“热”,虽然它在技术上可行,但有点违背了将其作为无服务器数据库的意义(成本原因)。如果超时是连接错误,我愿意让我的客户端重试 API 调用。

这是日志,以防它们有任何帮助。

{
"name": "SequelizeConnectionError",
"parent": {
"errorno": "ETIMEDOUT",
"code": "ETIMEDOUT",
"syscall": "connect",
"fatal": true
},
"original": {
"errorno": "ETIMEDOUT",
"code": "ETIMEDOUT",
"syscall": "connect",
"fatal": true
}
}

最佳答案

所以在进一步挖掘之后,您似乎可以使用选项对象上的 dialectOptions 属性将内容传递给底层连接。

dialectOptions: {
connectTimeout: 60000
}

这似乎可以解决问题。

关于mysql - 使用 Serverless Aurora 时 Sequelize 连接超时,寻找增加超时持续时间或重试连接的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52465530/

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