我正在使用central_logger来存储mongodb中我们的Rails应用程序中的日志。当mongo服务器最近关闭时,我们的应用程序开始计时mongo插入。如果mongo服务器出现故障,如何防止Rails超时?
答案 0 :(得分:1)
ruby driver支持超时
@conn = Connection.new("localhost", 27017, :pool_size => 5, :timeout => 5)
但是central_logger gem没有使用它。所以你可以将它分叉以在那里添加,或者使用Monkey-path的CentralLogger :: MongoLogger.connect方法
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毫秒后继续。