首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ruby 'reconnect‘对象变量

Ruby 'reconnect‘对象变量
EN

Stack Overflow用户
提问于 2012-07-17 10:06:00
回答 1查看 899关注 0票数 0

在脚本运行了一定时间之后,我在Ruby中遇到了'mysql已经消失‘的错误。

当连接丢失时,我想尝试告诉mysql自动重新连接。

我的当前代码如下所示:

代码语言:javascript
复制
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宝石。

EN

回答 1

Stack Overflow用户

发布于 2012-07-17 17:55:03

如果您要开始一个新项目,那么mysql2创业板就是最好的选择。这比旧版本有了很大的改进。

试图对您的示例进行Ruby化的尝试是:

代码语言:javascript
复制
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

与其使用单例类,不如使用单例实例。例如:

代码语言:javascript
复制
class MyApp
  def self.db
    @db ||= Database.new
  end

  class Database
    # Instance methods like initialize, connect, disconnect, etc.
  end
 end

您可以这样使用:

代码语言:javascript
复制
MyApp.db.connect

直接使用类的实例而不是类的优点是一次可以支持多个连接。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11520245

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档