我有一个简单的 Sinatra 应用程序托管在 Heroku 上,并使用 Sequel 通过 ClearDB 插件连接到 MySql 数据库。
该应用程序工作正常,除非它空闲超过一分钟。在这种情况下,我发出的第一个请求给出了“500 内部服务器错误”,heroku logs
显示为:
sequel::DatabaseDisconnectError - Mysql::Error: MySQL server has gone away
如果我在此错误后刷新页面,它可以正常工作,并且在应用程序空闲一分钟左右之前,错误不会返回。
该应用程序正在运行两个测功机,因此问题不是由您可能在免费帐户上看到的 Heroku 测功机空闲引起的。我联系了 ClearDB 支持,他们给了我这个建议:
如果您正在使用连接池,那么您应该将空闲超时设置为略低于 60 秒和/或设置一个保持活动状态,如下所述。如果您没有使用连接池,那么您必须确保应用程序在查询后实际关闭连接,并且不依赖网络超时来关闭它们。
我知道我可以创建一个 cron 作业来每隔 30 秒左右访问一次服务器,但这似乎是一个不雅的解决方案。关于确保应用程序关闭我不理解的连接的另一个建议。我只是使用 Sequel 进行查询,我假设 Sequel 在后台为我管理连接。我是否需要对其进行配置以确保它关闭连接?我该怎么做?