Sha256: 366c2bc72bde5b2ca052b83ca8252bcbb86c7520efa096bcfb9db03c4bee96a7

Contents?: true

Size: 1.49 KB

Versions: 7

Compression:

Stored size: 1.49 KB

Contents

require 'redis/distributed'

class Redis
  class DistributedStore < Distributed
    @@timeout = 5
    attr_reader :ring

    def initialize(addresses, options = {})
      _extend_namespace options
      @ring = options[:ring] || Redis::HashRing.new([], options[:replicas] || Redis::HashRing::POINTS_PER_SERVER)

      addresses.each do |address|
        @ring.add_node(::Redis::Store.new _merge_options(address, options))
      end
    end

    def nodes
      ring.nodes
    end

    def reconnect
      nodes.each { |node| node.reconnect }
    end

    def set(key, value, options = nil)
      node_for(key).set(key, value, options)
    end

    def get(key, options = nil)
      node_for(key).get(key, options)
    end

    def setnx(key, value, options = nil)
      node_for(key).setnx(key, value, options)
    end

    def redis_version
      nodes.first.redis_version unless nodes.empty?
    end

    def supports_redis_version?(version)
      if nodes.empty?
        false
      else
        nodes.first.supports_redis_version?(version)
      end
    end

    def setex(key, expiry, value, options = nil)
      node_for(key).setex(key, expiry, value, options)
    end

    private
      def _extend_namespace(options)
        @namespace = options[:namespace]
        extend ::Redis::Store::Namespace if @namespace
      end

      def _merge_options(address, options)
        address.merge(
          :timeout => options[:timeout] || @@timeout,
          :namespace => options[:namespace]
        )
      end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
redis-store-1.9.2 lib/redis/distributed_store.rb
redis-store-1.9.1 lib/redis/distributed_store.rb
redis-store-1.9.0 lib/redis/distributed_store.rb
redis-store-1.8.2 lib/redis/distributed_store.rb
redis-store-1.8.1 lib/redis/distributed_store.rb
redis-store-1.8.0 lib/redis/distributed_store.rb
redis-store-1.6.0 lib/redis/distributed_store.rb