Jon*_*nah 4 ruby heroku sinatra sequel cleardb
我有一个简单的 Sinatra 应用程序托管在 Heroku 上,并使用 Sequel 通过 ClearDB 插件连接到 MySql 数据库。
该应用程序工作正常,除非它闲置超过一分钟。在这种情况下,我发出的第一个请求给出了“500 内部服务器错误”,heroku logs显示为:
sequel::DatabaseDisconnectError - Mysql::Error: MySQL server has gone away
Run Code Online (Sandbox Code Playgroud)
如果我在出现此错误后刷新页面,则它工作正常,并且直到应用程序闲置一分钟左右,错误才会返回。
该应用程序正在运行两个 dyno,因此问题不是由您可能在免费帐户上看到的 Heroku dyno 空闲引起的。我联系了 ClearDB 支持,他们给了我以下建议:
如果您使用连接池,那么您应该将空闲超时设置为略低于 60 秒和/或设置保持活动状态,如下所述。如果您没有使用连接池,那么您必须确保应用程序在查询后实际关闭连接,并且不依赖网络超时来关闭它们。
我知道我可以创建一个 cron 作业来每 30 秒左右访问一次服务器,但这似乎是一个不雅的问题解决方案。关于确保应用程序关闭连接的另一个建议我不明白。我只是使用 Sequel 进行查询,我假设 Sequel 在幕后为我管理连接。我是否需要对其进行配置以确保它关闭连接?我该怎么做?
您的连接超时,这没什么大不了的。如果您将connection_validator扩展添加到数据库,Sequel 可以处理这种情况:
DB.extension(:connection_validator)
Run Code Online (Sandbox Code Playgroud)
如文档中所述,此扩展
“检测到无效连接,[...] 将其从池中删除并尝试下一个可用连接,如果没有可用连接有效则创建一个新连接”