Class: MultiThink::Connection
- Inherits:
-
Object
- Object
- MultiThink::Connection
- Defined in:
- lib/multithink/connection.rb
Constant Summary collapse
- DEFAULTS =
{retries: 10}
Instance Method Summary collapse
- #connect ⇒ Object
-
#initialize(servers, options = {}) ⇒ Connection
constructor
A new instance of Connection.
- #reconnect ⇒ Object
- #run(query, *args) ⇒ Object
Constructor Details
#initialize(servers, options = {}) ⇒ Connection
Returns a new instance of Connection.
11 12 13 14 15 16 |
# File 'lib/multithink/connection.rb', line 11 def initialize(servers, = {}) @servers = servers = DEFAULTS.merge() @retries = .fetch(:retries) connect end |
Instance Method Details
#connect ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/multithink/connection.rb', line 18 def connect @tried = 0 while @tried < @retries do @servers.each do |server| begin Timeout::timeout(1) do @conn = r.connect(server) end return true rescue sleep 1 end @tried += 1 end end # If we got here we couldn't get a connection. :( raise "Error: Reached maximum retries (#{@retries})" end |
#reconnect ⇒ Object
49 50 51 52 53 54 55 56 57 |
# File 'lib/multithink/connection.rb', line 49 def reconnect begin # try fast path first @conn.reconnect rescue # if that fails then try get a new connection connect end end |
#run(query, *args) ⇒ Object
37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/multithink/connection.rb', line 37 def run(query, *args) begin query.run(@conn, *args) rescue RethinkDB::RqlRuntimeError => e raise e rescue RuntimeError => e if reconnect retry end end end |