Method: Dalli::Ring#initialize
- Defined in:
- lib/dalli/ring.rb
#initialize(servers, options) ⇒ Ring
Returns a new instance of Ring.
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/dalli/ring.rb', line 10 def initialize(servers, ) @servers = servers @continuum = nil if servers.size > 1 total_weight = servers.inject(0) { |memo, srv| memo + srv.weight } continuum = [] servers.each do |server| entry_count_for(server, servers.size, total_weight).times do |idx| hash = Digest::SHA1.hexdigest("#{server.hostname}:#{server.port}:#{idx}") value = Integer("0x#{hash[0..7]}") continuum << Dalli::Ring::Entry.new(value, server) end end @continuum = continuum.sort { |a, b| a.value <=> b.value } end threadsafe! unless [:threadsafe] == false @failover = [:failover] != false end |