Memcached
MemcachedClientConfig
dataclass
¶
Configuration of the memcached client.
PARAMETER | DESCRIPTION |
---|---|
server |
A tuple of (IP|domain name, port). |
connect_timeout |
How many seconds to wait before raising
TYPE:
|
timeout |
Duration in seconds to wait for send or recv calls on the socket connected to memcached.
TYPE:
|
no_delay |
If True, set the
TYPE:
|
serde |
Serializer / Deserializer ("serde"). The default
TYPE:
|
MemcachedCacheBackend(config=MemcachedClientConfig())
¶
Bases: CacheBackend
Memcached cache backend for the distributed caching of functions.
Implements the CacheBackend interface for a memcached based cache. This allows sharing evaluations across processes and nodes in a cluster. You can run memcached as a service, locally or remotely, see Setting up the cache
PARAMETER | DESCRIPTION |
---|---|
config |
Memcached client configuration.
TYPE:
|
ATTRIBUTE | DESCRIPTION |
---|---|
config |
Memcached client configuration.
|
client |
Memcached client instance.
|
Examples
>>> from pydvl.utils.caching.memcached import MemcachedCacheBackend
>>> cache_backend = MemcachedCacheBackend()
>>> cache_backend.clear()
>>> value = 42
>>> cache_backend.set("key", value)
>>> cache_backend.get("key")
42
>>> from pydvl.utils.caching.memcached import MemcachedCacheBackend
>>> cache_backend = MemcachedCacheBackend()
>>> cache_backend.clear()
>>> value = 42
>>> def foo(x: int):
... return x + 1
...
>>> wrapped_foo = cache_backend.wrap(foo)
>>> wrapped_foo(value)
43
>>> wrapped_foo.stats.misses
1
>>> wrapped_foo.stats.hits
0
>>> wrapped_foo(value)
43
>>> wrapped_foo.stats.misses
1
>>> wrapped_foo.stats.hits
1
PARAMETER | DESCRIPTION |
---|---|
config |
Memcached client configuration.
TYPE:
|
Source code in src/pydvl/utils/caching/memcached.py
wrap(func, *, config=None)
¶
Wraps a function to cache its results.
PARAMETER | DESCRIPTION |
---|---|
func |
The function to wrap.
TYPE:
|
config |
Optional caching options for the wrapped function.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
CachedFunc
|
The wrapped cached function. |
Source code in src/pydvl/utils/caching/base.py
get(key)
¶
Get value from memcached.
PARAMETER | DESCRIPTION |
---|---|
key |
Cache key.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Optional[Any]
|
Cached value or None if not found or client disconnected. |
Source code in src/pydvl/utils/caching/memcached.py
set(key, value)
¶
clear()
¶
combine_hashes(*args)
¶
__getstate__()
¶
Enables pickling after a socket has been opened to the memcached server, by removing the client from the stored data.
__setstate__(d)
¶
Restores a client connection after loading from a pickle.
Created: 2023-12-21