Classes to add key prefix and stats to cachetools classes and use redis and memcached as storage backends, and other cache-related utils.
For our purpose, a cache is a key-value store, aka a dictionary, possibly with
some constraints on keys (type, size) and values (size, serialization).
This module provides new caches, wrappers and other utilities suitable to use
with cachetools
.
RedisCache
allows to see a Redis server as a python cache by wrapping aredis.Redis
instance.MemCached
does the same for a Memcached server. The utility classJsonSerde
is a convenient JSON serializer-deserializer class for Memcached.DictCache
a very simpledict
cache.
PrefixedCache
,PrefixedMemCached
andPrefixedRedisCache
add a prefix to distinguish sources on a shared cache.StatsCache
,MemCached
andRedisCache
add ahits
method to report the cache hit rate,stats
to report statistics andreset
to reset statistics.LockedCache
use a (thread) lock to control cache accesses.TwoLevelCache
allows to combine two caches.DebugCache
to trace cache calls usinglogging
.EncryptedCache
a cache with key hashing and value encryption.ToBytesCache
map keys and values to bytes.BytesCache
map bytes keys and values to strings.
cached
decorator: a cachetools replacement which allows to test if a function result is in cache, and to delete such an entry.cacheFunctions
andcacheMethods
: add caching to functions or methods.json_key
,hash_json_key
,full_hash_key
: convenient JSON-based cache key serialization functions forcached
.
This code is Public Domain.
All software has bug, this is software, hence… Beware that you may lose your hairs or your friends because of it. If you like it, feel free to send a postcard to the author.
See the documentation, sources and issues on GitHub.
See packages on PyPI.