Class: RedisCluster::Client

Inherits:
Object
  • Object
show all
Defined in:
lib/redis_cluster/client.rb

Instance Method Summary collapse

Constructor Details

#initialize(startup_hosts, global_configs) ⇒ Client

Returns a new instance of Client.



5
6
7
8
9
10
# File 'lib/redis_cluster/client.rb', line 5

def initialize(startup_hosts, global_configs)
  @startup_hosts = startup_hosts
  @pool = Pool.new
  @locking = false
  reload_pool_nodes
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method, *args, &block) ⇒ Object



38
39
40
# File 'lib/redis_cluster/client.rb', line 38

def method_missing(method, *args, &block)
  execute(method, args)
end

Instance Method Details

#execute(method, args) ⇒ Object



12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/redis_cluster/client.rb', line 12

def execute(method, args)
  ttl = Configuration::REQUEST_TTL
  asking = false
  try_random_node = false

  while ttl > 0
    ttl -= 1
    begin
      return @pool.execute(method, args, {asking: asking, random_node: try_random_node})
    rescue Errno::ECONNREFUSED, Redis::TimeoutError, Redis::CannotConnectError, Errno::EACCES
      try_random_node = true
      sleep 0.1 if ttl < Configuration::REQUEST_TTL/2
    rescue => e
      err_code = e.to_s.split.first
      raise e unless %w(MOVED ASK).include?(err_code)

      if err_code == "ASK"
         asking = true
      else
        reload_pool_nodes
        sleep 0.1 if ttl < Configuration::REQUEST_TTL/2
      end
    end
  end
end