Ranter
Join devRant
Do all the things like
++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
Sign Up
Pipeless API
From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
Learn More
Comments
-
asgs112684y@Elyz data staleness and evictions have always been big problems but to classify those as biggest enemies makes it nothing but a joke
-
Caching is easier when you force yourself into a box.
Every key should expire. No exceptions.
Use LRU or (preferably) LFU (latter uses bloom-based eviction) guided by least TTL. Redis has support for this out of the box.
Everything you do should be atomic, unless where it doesn't need to be. This seems trivial and obvious but my God it's a concept I have to explain over and over again.
Passive vs active optimizations are IMO the best design. Have a guaranteed but possibly slower update loop that lazily updates and/or checks cache data from a source of truth. When the data changes, do a best-effort delete and then a best effort update in the cache. Worst case second fails and causes a refetch, but at least the data isn't stale. Send invalidations after user responses; log all failures as time series data points at the very least.
Lastly, make sure your application can survive without the cache at all. This doesn't mean services must work to their full potential, but at least shoot for a read-only mode. Degraded is better than down.
These are generalizations but help a lot
Caching - Our biggest enemy
joke/meme