Sha256: 87a4060ff3cdc2f2209742281dce3d04af42e969e5abf8717f81307ba2863007
Contents?: true
Size: 1.27 KB
Versions: 3
Compression:
Stored size: 1.27 KB
Contents
# -*- coding: utf-8 -*- require "bsearch" module ActiveRecord::Turntable::Algorithm class RangeBsearchAlgorithm < Base def initialize(config) @config = config @config[:shards].sort_by! { |a| a[:less_than] } end def calculate(key) idx = calculate_idx(key) @config[:shards][idx][:connection] rescue raise ActiveRecord::Turntable::CannotSpecifyShardError, "cannot specify shard for key:#{key}" end def calculate_idx(key) @config[:shards].bsearch_upper_boundary { |h| h[:less_than] <=> key } end # { connection_name => weight, ... } def calculate_used_shards_with_weight(sequence_value) idx = calculate_idx(sequence_value) last_connection = calculate(sequence_value) shards = @config[:shards][0..idx] weighted_hash = Hash.new { |h, k| h[k] = 0 } prev_max = 0 shards.each_with_index do |h, idx| weighted_hash[h[:connection]] += if idx < shards.size - 1 h[:less_than] - prev_max - 1 else sequence_value - prev_max end prev_max = h[:less_than] - 1 end weighted_hash end end end
Version data entries
3 entries across 3 versions & 1 rubygems