Sha256: 14230c19a0cdaf6edc85241e5c9392a0add5ac5178be4001d0972a45ba2b9f07
Contents?: true
Size: 1.7 KB
Versions: 2
Compression:
Stored size: 1.7 KB
Contents
require "dalli-elasticache" require "alephant/logger" module Alephant module Lookup class LookupCache include Logger attr_reader :config DEFAULT_TTL = 2 def initialize(config={}) @config = config unless config_endpoint.nil? @elasticache ||= ::Dalli::ElastiCache.new(config_endpoint, { :expires_in => ttl }) @client ||= @elasticache.client else logger.debug "Alephant::LookupCache::#initialize: No config endpoint, NullClient used" logger.metric "NoConfigEndpoint" @client = NullClient.new end end def get(key, &block) begin versioned_key = versioned key result = @client.get versioned_key logger.info "Alephant::LookupCache#get key: #{versioned_key} - #{result ? 'hit' : 'miss'}" logger.metric "GetKeyMiss" unless result result ? result : set(key, block.call) rescue StandardError => e block.call if block_given? end end def set(key, value, ttl = nil) value.tap { |o| @client.set(versioned(key), o, ttl) } end private def config_endpoint config[:elasticache_config_endpoint] || config["elasticache_config_endpoint"] end def ttl config[:lookup_elasticache_ttl] || config["lookup_elasticache_ttl"] || DEFAULT_TTL end def versioned(key) [key, cache_version].compact.join("_") end def cache_version config[:elasticache_cache_version] || config["elasticache_cache_version"] end end class NullClient def get(key); end def set(key, value, ttl = nil) value end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
alephant-lookup-2.1.0 | lib/alephant/lookup/lookup_cache.rb |
alephant-lookup-2.0.2 | lib/alephant/lookup/lookup_cache.rb |