4

我有一个简单的 Sinatra 应用程序托管在 Heroku 上,并使用 Sequel 通过 ClearDB 插件连接到 MySql 数据库。

该应用程序工作正常,除非它空闲超过一分钟。在这种情况下,我发出的第一个请求给出了“500 内部服务器错误”,heroku logs显示为:

sequel::DatabaseDisconnectError - Mysql::Error: MySQL server has gone away

如果我在此错误后刷新页面,它可以正常工作,并且在应用程序空闲一分钟左右之前,错误不会返回。

该应用程序正在运行两个测功机,因此问题不是由您可能在免费帐户上看到的 Heroku 测功机空闲引起的。我联系了 ClearDB 支持,他们给了我这个建议:

如果您正在使用连接池,那么您应该将空闲超时设置为略低于 60 秒和/或设置一个保持活动状态,如下所述。如果您没有使用连接池,那么您必须确保应用程序在查询后实际关闭连接,并且不依赖网络超时来关闭它们。

我知道我可以创建一个 cron 作业来每隔 30 秒左右访问一次服务器,但这似乎是一个不雅的解决方案。关于确保应用程序关闭我不理解的连接的另一个建议。我只是使用 Sequel 进行查询,我假设 Sequel 在后台为我管理连接。我是否需要对其进行配置以确保它关闭连接?我该怎么做?

4

1 回答 1

5

您的连接超时,这没什么大不了的。connection_validator如果您将扩展添加到数据库,Sequel 可以处理这种情况:

DB.extension(:connection_validator)

文档中所述,此扩展

“检测到无效连接,[...] 将其从池中删除并尝试下一个可用连接,如果没有可用连接有效,则创建一个新连接”

于 2017-10-13T06:25:48.513 回答