On 11/4/18 11:28pm, Andrus Adamchik wrote:
Also EhCache may actively remove expired items (?), but OSCache certainly did
not, and it was not a problem either, also because of maxsize/LRU.
Advertising
Actually that's a problem in EHcache that had us leave it and use
Caffeine instead. EHCache only tries to clean up memory when you write a
new item to the cache and it is hardcoded to try and evict two items for
every new item you add.
This is a real problem if you try to add a new 100Mb query result and it
happens to try to evict two 1kB queries already in the cache. Boom, your
app runs out of memory and dies. The response from the EHCache people
was that it works best when all items our roughly the same size.
Unfortunately the Cayenne query cache can easily add items with hugely
different sizes.
We found that caffeine gives us a little more control over this process
( https://github.com/ben-manes/caffeine/wiki/Cleanup ) and it is still a
trivial replacement since it implements jCache.
Caching is definitely not one of those "click this box to make
everything faster" and forget about it things.
Oh, hi everyone. I know I've been absent for a while... my life has been
a little crazy.
Ari