Class: Moneta::Adapters::LRUHash
- Inherits:
-
Object
- Object
- Moneta::Adapters::LRUHash
- Includes:
- CreateSupport, Defaults, IncrementSupport
- Defined in:
- lib/moneta/adapters/lruhash.rb
Overview
LRUHash backend
Based on Hashery::LRUHash but simpler and measures both memory usage and hash size.
Defined Under Namespace
Classes: Entry
Constant Summary collapse
- DEFAULT_MAX_SIZE =
1024000
- DEFAULT_MAX_COUNT =
10240
Instance Method Summary collapse
-
#clear(options = {}) ⇒ void
Clear all keys in this store.
-
#delete(key, options = {}) ⇒ Object
Delete the key from the store and return the current value.
-
#initialize(options = {}) ⇒ LRUHash
constructor
A new instance of LRUHash.
-
#key?(key, options = {}) ⇒ Boolean
Exists the value with key.
-
#load(key, options = {}) ⇒ Object
Fetch value with key.
-
#store(key, value, options = {}) ⇒ Object
Store value with key.
Methods included from CreateSupport
Methods included from IncrementSupport
Methods included from Defaults
#[], #[]=, #close, #create, #decrement, #features, #fetch, included, #increment, #supports?
Methods included from OptionSupport
#expires, #prefix, #raw, #with
Constructor Details
#initialize(options = {}) ⇒ LRUHash
Returns a new instance of LRUHash.
20 21 22 23 24 25 |
# File 'lib/moneta/adapters/lruhash.rb', line 20 def initialize( = {}) @max_size = .fetch(:max_size) { DEFAULT_MAX_SIZE } @max_count = .fetch(:max_count) { DEFAULT_MAX_COUNT } @max_value = [[:max_value], @max_size].compact.min clear end |
Instance Method Details
#clear(options = {}) ⇒ void
This method returns an undefined value.
Clear all keys in this store
69 70 71 72 73 74 |
# File 'lib/moneta/adapters/lruhash.rb', line 69 def clear( = {}) @entry, @size = {}, 0 @list = Entry.new @list.prev = @list.next = @list self end |
#delete(key, options = {}) ⇒ Object
Delete the key from the store and return the current value
60 61 62 63 64 65 66 |
# File 'lib/moneta/adapters/lruhash.rb', line 60 def delete(key, = {}) if entry = @entry.delete(key) @size -= entry.value.bytesize if @max_size entry.unlink entry.value end end |
#key?(key, options = {}) ⇒ Boolean
Exists the value with key
28 29 30 |
# File 'lib/moneta/adapters/lruhash.rb', line 28 def key?(key, = {}) @entry.key?(key) end |
#load(key, options = {}) ⇒ Object
Fetch value with key. Return nil if the key doesn’t exist
33 34 35 36 37 38 |
# File 'lib/moneta/adapters/lruhash.rb', line 33 def load(key, = {}) if entry = @entry[key] entry.insert_after(@list) entry.value end end |
#store(key, value, options = {}) ⇒ Object
Store value with key
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/moneta/adapters/lruhash.rb', line 41 def store(key, value, = {}) if @max_value && value.bytesize > @max_value delete(key) else if entry = @entry[key] @size -= entry.value.bytesize if @max_size else @entry[key] = entry = Entry.new entry.key = key end entry.value = value @size += entry.value.bytesize if @max_size entry.insert_after(@list) delete(@list.prev.key) while @list.next != @list.prev && (@max_size && @size > @max_size || @max_count && @entry.size > @max_count) end value end |