public class MemcachedHttpCacheStorage extends AbstractBinaryCacheStorage<net.spy.memcached.CASValue<Object>>
This class is a storage backend that uses an external memcached for storing cached origin responses. This storage option provides a couple of interesting advantages over the default in-memory storage backend:
Note that in a shared memcached pool setting you may wish to make use of the Ketama consistent hashing algorithm to reduce the number of cache misses that might result if one of the memcached cluster members fails (see the KetamaConnectionFactory).
Because memcached places limits on the size of its keys, we need to
introduce a key hashing scheme to map the annotated URLs the higher-level
caching HTTP client wants to use as keys onto ones that are suitable
for use with memcached. Please see KeyHashingScheme
if you would
like to use something other than the provided SHA256KeyHashingScheme
.
Please refer to the memcached documentation and in particular to the documentation for the spymemcached documentation for details about how to set up and configure memcached and the Java client used here, respectively.
Constructor and Description |
---|
MemcachedHttpCacheStorage(InetSocketAddress address)
Create a storage backend talking to a memcached instance
listening on the specified host and port.
|
MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClient cache)
Create a storage backend using the pre-configured given
memcached client.
|
MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClient client,
CacheConfig config,
HttpCacheEntrySerializer<byte[]> serializer,
KeyHashingScheme keyHashingScheme)
Create a storage backend using the given memcached client and
applying the given cache configuration, serialization, and hashing
mechanisms.
|
MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClientIF cache)
Create a storage backend using the pre-configured given
memcached client.
|
MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClientIF client,
CacheConfig config,
HttpCacheEntrySerializer<byte[]> serializer,
KeyHashingScheme keyHashingScheme)
Create a storage backend using the given memcached client and
applying the given cache configuration, serialization, and hashing
mechanisms.
|
Modifier and Type | Method and Description |
---|---|
protected Map<String,byte[]> |
bulkRestore(Collection<String> storageKeys) |
protected void |
delete(String storageKey) |
protected String |
digestToStorageKey(String key) |
protected net.spy.memcached.CASValue<Object> |
getForUpdateCAS(String storageKey) |
protected byte[] |
getStorageObject(net.spy.memcached.CASValue<Object> casValue) |
protected byte[] |
restore(String storageKey) |
protected void |
store(String storageKey,
byte[] storageObject) |
protected boolean |
updateCAS(String storageKey,
net.spy.memcached.CASValue<Object> casValue,
byte[] storageObject) |
getEntries, getEntry, putEntry, removeEntry, updateEntry
public MemcachedHttpCacheStorage(InetSocketAddress address) throws IOException
address
- where the memcached daemon is runningIOException
- in case of an errorpublic MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClient cache)
cache
- client to use for communicating with memcachedpublic MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClientIF cache)
cache
- client to use for communicating with memcachedpublic MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClient client, CacheConfig config, HttpCacheEntrySerializer<byte[]> serializer, KeyHashingScheme keyHashingScheme)
client
- how to talk to memcachedconfig
- apply HTTP cache-related optionsserializer
- alternative serialization mechanismkeyHashingScheme
- how to map higher-level logical "storage keys"
onto "cache keys" suitable for use with memcachedpublic MemcachedHttpCacheStorage(net.spy.memcached.MemcachedClientIF client, CacheConfig config, HttpCacheEntrySerializer<byte[]> serializer, KeyHashingScheme keyHashingScheme)
client
- how to talk to memcachedconfig
- apply HTTP cache-related optionsserializer
- alternative serialization mechanismkeyHashingScheme
- how to map higher-level logical "storage keys"
onto "cache keys" suitable for use with memcachedprotected String digestToStorageKey(String key)
digestToStorageKey
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
protected void store(String storageKey, byte[] storageObject) throws ResourceIOException
store
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected byte[] restore(String storageKey) throws ResourceIOException
restore
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected net.spy.memcached.CASValue<Object> getForUpdateCAS(String storageKey) throws ResourceIOException
getForUpdateCAS
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected byte[] getStorageObject(net.spy.memcached.CASValue<Object> casValue) throws ResourceIOException
getStorageObject
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected boolean updateCAS(String storageKey, net.spy.memcached.CASValue<Object> casValue, byte[] storageObject) throws ResourceIOException
updateCAS
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected void delete(String storageKey) throws ResourceIOException
delete
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
protected Map<String,byte[]> bulkRestore(Collection<String> storageKeys) throws ResourceIOException
bulkRestore
in class AbstractSerializingCacheStorage<byte[],net.spy.memcached.CASValue<Object>>
ResourceIOException
Copyright © 1999–2021 The Apache Software Foundation. All rights reserved.