Cache#
- class trytond.cache.Cache(name[, duration[, context[, context_ignored_keys]]])#
Use to cache values between server requests.
The
name
should be unique and it’s used to identify the cache. Usually<class_name>.<content_name>
is used to make it unique.The
duration
parameter defines how long a cached value stays valid but if it is not set the value remains valid until it is cleared.And the
context
parameter is used to indicate if the cache depends on the user context and isTrue
by default. Keys specified incontext_ignored_keys
are ignored.The cache is cleaned on
Transaction
starts and resets onTransaction
commit or rollback.Warning
As there is no deepcopy of the values cached, they must never be mutated after being set in or retrieved from the cache.
- Cache.size_limit#
The maximal number of values cached. The value comes from the entry with the same
name
under thecache
section of the configuration using thedefault
entry as default value.
- Cache.hit#
Count the number of times the cache returned a cached value.
- Cache.miss#
Count the number of times the cache did not contain the key.
- classmethod Cache.stats()#
Yield statistics for each instance.
- Cache.get(key[, default])#
Retrieve the value of the key in the cache.
If a
default
is specified it is returned when the key is missing otherwise it returnsNone
.
- Cache.set(key, value)#
Set the
value
of thekey
in the cache.
- Cache.clear()#
Clear all the keys in the cache.
- classmethod Cache.clear_all()#
Clear all cache instances.
- classmethod Cache.sync(transaction)#
Synchronize caches between servers using
transaction
instance.
- Cache.sync_since(value)#
Return
True
if the last synchronization was done beforevalue
.
- classmethod Cache.commit(transaction)#
Apply cache changes from transaction.
- classmethod Cache.rollback(transaction)#
Remove cache changes from transaction.
- classmethod Cache.drop(dbname)#
Drop all caches for named database.
Note
By default Tryton uses a MemoryCache, but this behaviour can be overridden
by setting a fully qualified name of an alternative class defined in the
configuration class
of the cache
section.