我使用Sequel gem连接数据库。但是,DB服务器是远程的,所以我必须首先通过SSH登录。
我的Ruby脚本设置为每隔五分钟SSH,ping数据库,然后关闭SSH连接。 (SSH由Net :: SSH :: Gateway处理。)
但我最近在MySQL上遇到了“连接太多”错误。在检查MySQL进程列表时,我发现了Ruby脚本中的一堆休眠连接。所以我在我的脚本中添加了db.disconnect
行,以便在关闭SSH连接之前断开与数据库的连接,这似乎解决了这个问题。
我的问题是,数据库连接是否自动关闭?为什么有一堆睡眠SQL连接?
答案 0 :(得分:1)
由于您没有提供指向您正在使用的脚本的链接,因此很难准确说明发生了什么。根据提供的有限信息,您可能每五分钟创建一个新的Sequel :: Database对象。 Sequel :: Database对象旨在提供与数据库的持久连接,通常在应用程序启动期间创建并存储在常量中。
通常,您应该创建一个Sequel :: Database对象,并且每5分钟发送一次简单查询。或者,您应该为创建Sequel :: Database对象的方法提供一个块,以便在块返回时自动关闭它。