ezmobius (owner)

Forks

Revisions

gist: 221926 Download_button fork
public
Public Clone URL: git://gist.github.com/221926.git
Embed All Files: show embed
Text only #
1
2
3
4
5
6
7
8
9
10
11
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
require 'rubygems'
require 'eventmachine'
require 'redis'
require 'hash_ring'
 
class RedisProcz < EventMachine::Connection
  
  def initialize
    @ring = HashRing.new
  end
 
  def receive_data(data)
    p [:recieve_data, data]
    cmd, key, _ = data.split(/\s/)
    if cmd && key
      key = key.chomp
      p [:cmd, cmd]
      p [:key, key]
      redis = node_for_key(key)
      redis.send_data data
    end
  end
 
  def redis_server(host, port)
    srv = EventMachine::connect(host, port, RedisProczBackend) do |c|
      c.client = self
    end
    @ring.add_node(srv)
  end
  
  def node_for_key(key)
    key = $1 if key =~ /\{(.*)?\}/
    p ["choosing node for key: #{key}"]
    @ring.get_node(key)
  end
 
  def proxy_from_backend(data)
    p [:proxy_from_backend, data]
    send_data data unless data.nil?
  end
 
end
 
class RedisProczBackend < EventMachine::Connection
  attr_accessor :client
 
  def receive_data(data)
    @client.proxy_from_backend(data)
  end
end
 
 
EM.run {
  EM.start_server("127.0.0.1", 1024, RedisProcz) {|conn|
    conn.redis_server('localhost', 6379)
    conn.redis_server('localhost', 6380)
    conn.redis_server('localhost', 6381)
  }
}