Class: Sinatra::Cache::RedisStore
- Inherits:
-
Object
- Object
- Sinatra::Cache::RedisStore
- Defined in:
- lib/cache/sinatra/redis_store.rb
Instance Method Summary collapse
-
#clear ⇒ Object
Clear all the data from the store.
-
#decrement(key, amount = 1) ⇒ Object
Decrement a key in the store.
- #delete(key, options = nil) ⇒ Object
-
#delete_matched(matcher, options = nil) ⇒ Object
Delete objects for matched keys.
- #exist?(key, options = nil) ⇒ Boolean
- #fetch(key, options = {}) ⇒ Object
-
#increment(key, amount = 1) ⇒ Object
Increment a key in the store.
-
#initialize(*addresses) ⇒ RedisStore
constructor
Instantiate the store.
- #read(key, options = nil) ⇒ Object
- #stats ⇒ Object
- #write(key, value, options = nil) ⇒ Object
Constructor Details
#initialize(*addresses) ⇒ RedisStore
Instantiate the store.
Example:
RedisStore.new # => host: localhost, port: 6379, db: 0
RedisStore.new "example.com" # => host: example.com, port: 6379, db: 0
RedisStore.new "example.com:23682" # => host: example.com, port: 23682, db: 0
RedisStore.new "example.com:23682/1" # => host: example.com, port: 23682, db: 1
RedisStore.new "localhost:6379/0", "localhost:6380/0" # => instantiate a cluster
18 19 20 |
# File 'lib/cache/sinatra/redis_store.rb', line 18 def initialize(*addresses) @data = Redis::Factory.create addresses end |
Instance Method Details
#clear ⇒ Object
Clear all the data from the store.
105 106 107 |
# File 'lib/cache/sinatra/redis_store.rb', line 105 def clear @data.flushdb end |
#decrement(key, amount = 1) ⇒ Object
Decrement a key in the store
If the key doesn’t exist it will be initialized on 0. If the key exist but it isn’t a Fixnum it will be initialized on 0.
Example:
We have two objects in cache:
counter # => 23
rabbit # => #<Rabbit:0x5eee6c>
cache.decrement "counter"
cache.read "counter", :raw => true # => "22"
cache.decrement "counter", 2
cache.read "counter", :raw => true # => "20"
cache.decrement "a counter"
cache.read "a counter", :raw => true # => "-1"
cache.decrement "rabbit"
cache.read "rabbit", :raw => true # => "-1"
88 89 90 |
# File 'lib/cache/sinatra/redis_store.rb', line 88 def decrement(key, amount = 1) @data.decrby key, amount end |
#delete(key, options = nil) ⇒ Object
34 35 36 |
# File 'lib/cache/sinatra/redis_store.rb', line 34 def delete(key, = nil) @data.del key end |
#delete_matched(matcher, options = nil) ⇒ Object
Delete objects for matched keys.
Example:
cache.del_matched "rab*"
96 97 98 |
# File 'lib/cache/sinatra/redis_store.rb', line 96 def delete_matched(matcher, = nil) @data.keys(matcher).each { |key| @data.del key } end |
#exist?(key, options = nil) ⇒ Boolean
38 39 40 |
# File 'lib/cache/sinatra/redis_store.rb', line 38 def exist?(key, = nil) @data.exists key end |
#fetch(key, options = {}) ⇒ Object
100 101 102 |
# File 'lib/cache/sinatra/redis_store.rb', line 100 def fetch(key, = {}) (![:force] && data = read(key, )) || (write key, yield, if block_given?) end |
#increment(key, amount = 1) ⇒ Object
Increment a key in the store.
If the key doesn’t exist it will be initialized on 0. If the key exist but it isn’t a Fixnum it will be initialized on 0.
Example:
We have two objects in cache:
counter # => 23
rabbit # => #<Rabbit:0x5eee6c>
cache.increment "counter"
cache.read "counter", :raw => true # => "24"
cache.increment "counter", 6
cache.read "counter", :raw => true # => "30"
cache.increment "a counter"
cache.read "a counter", :raw => true # => "1"
cache.increment "rabbit"
cache.read "rabbit", :raw => true # => "1"
63 64 65 |
# File 'lib/cache/sinatra/redis_store.rb', line 63 def increment(key, amount = 1) @data.incrby key, amount end |
#read(key, options = nil) ⇒ Object
30 31 32 |
# File 'lib/cache/sinatra/redis_store.rb', line 30 def read(key, = nil) @data.marshalled_get(key, ) end |
#stats ⇒ Object
109 110 111 |
# File 'lib/cache/sinatra/redis_store.rb', line 109 def stats @data.info end |
#write(key, value, options = nil) ⇒ Object
22 23 24 25 26 27 28 |
# File 'lib/cache/sinatra/redis_store.rb', line 22 def write(key, value, = nil) if && [:unless_exist] @data.marshalled_setnx key, value, else @data.marshalled_set key, value, end end |