Sha256: 2d1bece7960ea736ad0fd73bab54d8ec53417e5272ef8265ed97a41216ca0cbf
Contents?: true
Size: 1.83 KB
Versions: 1
Compression:
Stored size: 1.83 KB
Contents
require 'dalli' require 'alephant/logger' module Alephant module Broker module Cache class Client include Logger DEFAULT_TTL = 2_592_000 def initialize if config_endpoint.nil? logger.debug 'Broker::Cache::Client#initialize: No config endpoint, NullClient used' logger.metric 'NoConfigEndpoint' @client = NullClient.new else @client ||= Dalli::Client.new(config_endpoint, expires_in: ttl) end end def get(key) versioned_key = versioned(key) result = @client.get(versioned_key) logger.info("Broker::Cache::Client#get key: #{versioned_key} - #{result ? 'hit' : 'miss'}") logger.metric('GetKeyMiss') unless result return result if result set(key, yield) if block_given? rescue StandardError => error logger.info(event: 'ErrorCaught', method: "#{self.class}#get", error: error) yield if block_given? end def set(key, value, custom_ttl = nil) versioned_key = versioned(key) set_ttl = custom_ttl || ttl logger.info("#{self.class}#set - key: #{versioned_key}, ttl: #{set_ttl}") @client.set(versioned_key, value, set_ttl) value end private def config_endpoint Broker.config[:elasticache_config_endpoint] || Broker.config['elasticache_config_endpoint'] end def ttl Broker.config[:elasticache_ttl] || Broker.config['elasticache_ttl'] || DEFAULT_TTL end def versioned(key) [key, cache_version].compact.join('_') end def cache_version Broker.config[:elasticache_cache_version] || Broker.config['elasticache_cache_version'] end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
alephant-broker-3.18.0 | lib/alephant/broker/cache/client.rb |