Class: Memcached::Rails
Overview
A legacy compatibility wrapper for the Memcached class. It has basic compatibility with the memcache-client API and Rails 3.2. (Note that ActiveSupport::Duration objects are supported, but not recommended, as ttl parameters. Using Fixnum ttls, such as provided by time_constants.gem, is much faster.)
Constant Summary collapse
- DEFAULTS =
{ :logger => nil, :string_return_types => false }
Constants inherited from Memcached
BEHAVIORS, BEHAVIOR_VALUES, CONVERSION_FACTORS, DIRECT_VALUE_BEHAVIORS, DISTRIBUTION_VALUES, ERRNO_HASH, EXCEPTIONS, FLAGS, HASH_VALUES, IGNORED, Lib, VERSION
Instance Attribute Summary collapse
-
#logger ⇒ Object
Returns the value of attribute logger.
Attributes inherited from Memcached
Instance Method Summary collapse
-
#active? ⇒ Boolean
Check if there are any servers defined?.
-
#add(key, value, ttl = @default_ttl, raw = false) ⇒ Object
Wraps Memcached#add so that it doesn’t raise.
-
#append(*args) ⇒ Object
Wraps Memcached#append so that it doesn’t raise.
-
#cas(key, ttl = @default_ttl, raw = false, &block) ⇒ Object
(also: #compare_and_swap)
Wraps Memcached#cas so that it doesn’t raise.
-
#decr(*args) ⇒ Object
Wraps Memcached#decr so that it doesn’t raise.
- #decrement(name, amount = 1, options = nil) ⇒ Object
-
#delete(key, options = nil) ⇒ Object
Wraps Memcached#delete so that it doesn’t raise.
-
#exist?(key, options = {}) ⇒ Boolean
Returns whether the key exists, even if the value is nil.
- #fetch(key, options = nil) ⇒ Object
-
#get(key, raw = false) ⇒ Object
(also: #[])
Wraps Memcached#get so that it doesn’t raise.
-
#get_multi(keys, raw = false) ⇒ Object
Wraps Memcached#get.
-
#incr(*args) ⇒ Object
Wraps Memcached#incr so that it doesn’t raise.
- #increment(name, amount = 1, options = nil) ⇒ Object
-
#initialize(*args) ⇒ Rails
constructor
See Memcached#new for details.
- #log_exception(e) ⇒ Object
- #namespace ⇒ Object
-
#prepend(*args) ⇒ Object
Wraps Memcached#prepend so that it doesn’t raise.
-
#read(key, options = nil) ⇒ Object
Alternative to #get.
- #read_multi(*keys) ⇒ Object
-
#servers ⇒ Object
Return an array of server objects.
- #servers= ⇒ Object
-
#set(key, value, ttl = @default_ttl, raw = false) ⇒ Object
(also: #[]=)
Wraps Memcached#set.
-
#set_servers(servers) ⇒ Object
Wraps Memcached#set_servers to convert server objects to strings.
-
#write(key, value, options = nil) ⇒ Object
Alternative to #set.
Methods inherited from Memcached
#clone, #destroy_credentials, #exist, #flush, #get_from_last, load_constants, #prefix_key, #quit, #replace, #reset, #server_by_key, #set_prefix_key, #should_retry, #stats
Constructor Details
#initialize(*args) ⇒ Rails
See Memcached#new for details.
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/memcached/rails.rb', line 22 def initialize(*args) opts = args.last.is_a?(Hash) ? args.pop : {} servers = Array( args.any? ? args.unshift : opts.delete(:servers) ).flatten.compact opts[:prefix_key] = opts.delete(:namespace) if opts[:namespace] opts[:prefix_delimiter] = opts.delete(:namespace_separator) if opts[:namespace_separator] @logger = opts.delete(:logger) @string_return_types = opts.delete(:string_return_types) logger.info { "memcached #{VERSION} #{servers.inspect}" } if logger super(servers, opts) end |
Instance Attribute Details
#logger ⇒ Object
Returns the value of attribute logger.
17 18 19 |
# File 'lib/memcached/rails.rb', line 17 def logger @logger end |
Instance Method Details
#active? ⇒ Boolean
Check if there are any servers defined?
47 48 49 |
# File 'lib/memcached/rails.rb', line 47 def active? servers.any? end |
#add(key, value, ttl = @default_ttl, raw = false) ⇒ Object
Wraps Memcached#add so that it doesn’t raise.
153 154 155 156 157 158 159 160 161 162 163 |
# File 'lib/memcached/rails.rb', line 153 def add(key, value, ttl=@default_ttl, raw=false) super(key, value, ttl, !raw) @string_return_types ? "STORED\r\n" : true rescue TypeError => e # Maybe we got an ActiveSupport::Duration ttl = ttl.value and retry rescue raise e rescue NotStored rescue Error => e log_exception e @string_return_types? "NOT STORED\r\n" : false end |
#append(*args) ⇒ Object
Wraps Memcached#append so that it doesn’t raise.
190 191 192 193 194 195 |
# File 'lib/memcached/rails.rb', line 190 def append(*args) super rescue NotStored rescue Error => e log_exception e end |
#cas(key, ttl = @default_ttl, raw = false, &block) ⇒ Object Also known as: compare_and_swap
Wraps Memcached#cas so that it doesn’t raise. Doesn’t set anything if no value is present.
89 90 91 92 93 94 95 96 97 98 99 |
# File 'lib/memcached/rails.rb', line 89 def cas(key, ttl=@default_ttl, raw=false, &block) super(key, ttl, !raw, &block) true rescue TypeError => e # Maybe we got an ActiveSupport::Duration ttl = ttl.value and retry rescue raise e rescue NotFound, ConnectionDataExists false rescue Error => e log_exception e end |
#decr(*args) ⇒ Object
Wraps Memcached#decr so that it doesn’t raise.
182 183 184 185 186 187 |
# File 'lib/memcached/rails.rb', line 182 def decr(*args) super rescue NotFound rescue Error => e log_exception e end |
#decrement(name, amount = 1, options = nil) ⇒ Object
241 242 243 244 245 246 |
# File 'lib/memcached/rails.rb', line 241 def decrement(name, amount = 1, = nil) response = super(name, amount) response ? response.to_i : nil rescue nil end |
#delete(key, options = nil) ⇒ Object
Wraps Memcached#delete so that it doesn’t raise.
166 167 168 169 170 171 |
# File 'lib/memcached/rails.rb', line 166 def delete(key, = nil) super(key) rescue NotFound rescue Error => e log_exception e end |
#exist?(key, options = {}) ⇒ Boolean
Returns whether the key exists, even if the value is nil.
79 80 81 82 83 84 85 86 |
# File 'lib/memcached/rails.rb', line 79 def exist?(key, = {}) exist(key) true rescue NotFound false rescue Error => e log_exception e end |
#fetch(key, options = nil) ⇒ Object
137 138 139 140 141 142 143 144 145 146 147 148 149 150 |
# File 'lib/memcached/rails.rb', line 137 def fetch(key, = nil) result = read(key, ) if result.nil? if block_given? result = yield write(key, result, ) result else result end else result end end |
#get(key, raw = false) ⇒ Object Also known as: []
Wraps Memcached#get so that it doesn’t raise. This has the side-effect of preventing you from storing nil
values.
58 59 60 61 62 63 |
# File 'lib/memcached/rails.rb', line 58 def get(key, raw=false) super(key, !raw) rescue NotFound rescue Error => e log_exception e end |
#get_multi(keys, raw = false) ⇒ Object
Wraps Memcached#get.
104 105 106 107 108 109 |
# File 'lib/memcached/rails.rb', line 104 def get_multi(keys, raw=false) get_orig(keys, !raw) rescue NotFound rescue Error => e log_exception e end |
#incr(*args) ⇒ Object
Wraps Memcached#incr so that it doesn’t raise.
174 175 176 177 178 179 |
# File 'lib/memcached/rails.rb', line 174 def incr(*args) super rescue NotFound rescue Error => e log_exception e end |
#increment(name, amount = 1, options = nil) ⇒ Object
234 235 236 237 238 239 |
# File 'lib/memcached/rails.rb', line 234 def increment(name, amount = 1, = nil) response = super(name, amount) response ? response.to_i : nil rescue nil end |
#log_exception(e) ⇒ Object
51 52 53 54 |
# File 'lib/memcached/rails.rb', line 51 def log_exception(e) logger.warn("memcached error: #{e.class}: #{e.}") if logger false end |
#namespace ⇒ Object
42 43 44 |
# File 'lib/memcached/rails.rb', line 42 def namespace @options[:prefix_key] end |
#prepend(*args) ⇒ Object
Wraps Memcached#prepend so that it doesn’t raise.
198 199 200 201 202 203 |
# File 'lib/memcached/rails.rb', line 198 def prepend(*args) super rescue NotStored rescue Error => e log_exception e end |
#read(key, options = nil) ⇒ Object
Alternative to #get. Accepts a key and an optional options hash supporting the single option :raw.
67 68 69 70 71 72 73 74 75 76 |
# File 'lib/memcached/rails.rb', line 67 def read(key, = nil) if get(key, [:raw]) else get(key) end rescue NotFound rescue Error => e log_exception e end |
#read_multi(*keys) ⇒ Object
211 212 213 214 |
# File 'lib/memcached/rails.rb', line 211 def read_multi(*keys) return {} if keys.empty? get_multi(keys) end |
#servers ⇒ Object
Return an array of server objects.
217 218 219 220 221 222 223 |
# File 'lib/memcached/rails.rb', line 217 def servers server_structs.each do |server| def server.alive? next_retry <= Time.now end end end |
#servers= ⇒ Object
19 |
# File 'lib/memcached/rails.rb', line 19 alias :servers= :set_servers |
#set(key, value, ttl = @default_ttl, raw = false) ⇒ Object Also known as: []=
Wraps Memcached#set.
112 113 114 115 116 117 118 119 120 121 122 |
# File 'lib/memcached/rails.rb', line 112 def set(key, value, ttl=@default_ttl, raw=false) super(key, value, ttl, !raw) true rescue TypeError => e # Maybe we got an ActiveSupport::Duration ttl = ttl.value and retry rescue raise e rescue NotStored false rescue Error => e log_exception e end |
#set_servers(servers) ⇒ Object
Wraps Memcached#set_servers to convert server objects to strings.
226 227 228 229 230 231 232 |
# File 'lib/memcached/rails.rb', line 226 def set_servers(servers) servers = Array(servers) servers.map! do |server| server.is_a?(String) ? server : inspect_server(server) end super end |
#write(key, value, options = nil) ⇒ Object
Alternative to #set. Accepts a key, value, and an optional options hash supporting the options :raw and :ttl.
126 127 128 129 130 131 132 133 134 135 |
# File 'lib/memcached/rails.rb', line 126 def write(key, value, = nil) value = value.to_s if && [:raw] ttl = ? ([:ttl] || [:expires_in] || @default_ttl) : @default_ttl raw = ? [:raw] : nil if && [:unless_exist] add(key, value, ttl, raw) else set(key, value, ttl, raw) end end |