在脚本运行了一定时间之后,我在Ruby中遇到了'mysql已经消失‘的错误。
当连接丢失时,我想尝试告诉mysql自动重新连接。
我的当前代码如下所示:
def self.connect()
begin
if !@@dbh.nil?
self.disconnect
end
@@dbh = Mysql.real_connect(@@server, @@user, @@pass, @@db)
puts "[+] Connected to the " + @@db + " database with user '" + @@user + "'"
rescue Mysql::Error => e
# log error
end
end下面的指南说,mysql有一个“重新连接”对象变量,但是我不知道如何在我的代码中使用它。
如何将此选项实现到上面的代码中?
谢谢你,瑞恩
0
编辑-
好的。我想我已经搞清楚了。
我需要在@@dbh.reconnect = true行之后添加@@dbh = Mysql.real_connect(@@server, @@user, @@pass, @@db)。
注意:根据IRC上的“不错”查比,mysql可能不是最好的Ruby宝石。
发布于 2012-07-17 17:55:03
如果您要开始一个新项目,那么mysql2创业板就是最好的选择。这比旧版本有了很大的改进。
试图对您的示例进行Ruby化的尝试是:
def connect
begin
if (@dbh)
self.disconnect
end
@dbh = Mysql.real_connect(@server, @user, @pass, @db)
puts "[+] Connected to the #{@db} database with user '#{@user}'"
rescue Mysql::Error => e
# log error
end
end使用传统@变量的原因是,如果您正确设计接口,就可以使用attr_accessor。
与其使用单例类,不如使用单例实例。例如:
class MyApp
def self.db
@db ||= Database.new
end
class Database
# Instance methods like initialize, connect, disconnect, etc.
end
end您可以这样使用:
MyApp.db.connect直接使用类的实例而不是类的优点是一次可以支持多个连接。
https://stackoverflow.com/questions/11520245
复制相似问题