Mongodb服务器出现故障,如何防止Rails应用超时?

时间:2011-05-03 13:47:44

标签: ruby-on-rails ruby mongodb

我正在使用central_logger来存储mongodb中我们的Rails应用程序中的日志。当mongo服务器最近关闭时,我们的应用程序开始计时mongo插入。如果mongo服务器出现故障,如何防止Rails超时?

3 个答案:

答案 0 :(得分:1)

ruby driver支持超时

@conn = Connection.new("localhost", 27017, :pool_size => 5, :timeout => 5)

但是central_logger gem没有使用它。所以你可以将它分叉以在那里添加,或者使用Monkey-path的CentralLogger :: MongoLogger.connect方法

currently has

def connect
    @mongo_connection ||= Mongo::Connection.new(@db_configuration['host'],
                                                @db_configuration['port'],
                                                :auto_reconnect => true).db(@db_configuration['database'])

    if @db_configuration['username'] && @db_configuration['password']
      # the driver stores credentials in case reconnection is required
      @authenticated = @mongo_connection.authenticate(@db_configuration['username'],
                                                      @db_configuration['password'])
    end
  end

你需要monkey-path in:timeout => 5(或其他)到Mongo :: Connection.new

我敢打赌,中央记录器的作者希望在那里有这个,所以欢迎fork和pull请求。

答案 1 :(得分:0)

您可以使用replica sets - 因此,如果主服务器关闭,它可以自动故障转移到其中一个副本。

答案 2 :(得分:0)

通常数据库插入应该很快,因此您可以使用ruby超时:

require 'timeout'
Timeout::timeout(0.2) do
  ... write to log server
end

此代码将超时并在任何情况下在200毫秒后继续。