我们一直在使用 Aurora 无服务器数据库在 AWS Lambda / API Gateway 之外运行我们的生产 Web 应用程序。一年多来事情一直顺利进行,但最近(与高峰使用期的增加相吻合)我们经历了暂时的缓慢,在最坏的情况下,由于某种瓶颈导致数量激增而无法使用数据库连接数以及来自我们两个 API 的 4XX 和 5XX。
我们使用serverless-mysql库来执行查询和管理数据库连接。
已消除该问题的一些潜在原因:
- 没有长时间运行的查询锁定表或任何类似的东西(如
show full processlist
MySQL 所示),实际上没有查询运行时间超过 1 秒。slow_log
- 所有的调用
await serverlessMysql.query()
都紧随其后await serverlessMysql.end()
- 我们的数据库管理器类在 Lambda 处理程序之外实例化,因此不会在每次重用 Lambda 实例时重新实例化
- 我们已经调整了 serverless-mysql 的配置选项,这样重试就不会那么激进了。默认配置使其在重试连接时非常激进,无论是频率还是重试次数。这肯定有帮助,但并没有消除问题。
我可以发布哪些详细信息可以帮助某人诊断此问题?这是一个很大的痛苦。