Bypass stale cache in unstable_cache
Unanswered
Large oak-apple gall posted this in #help-forum
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
I want to use unstable cache to serve previous data for some time. But after that time I want it to fetch new data on first request instead of serving stale data and revalidating it meanwhile.
Is it possible?
Is it possible?
26 Replies
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
A little delay wouldnt hurt as much as visitor coming week after last visit and getting week old data which should be refetched 5 minutes after last request
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall A little delay wouldnt hurt as much as visitor coming week after last visit and getting week old data which should be refetched 5 minutes after last request
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
if you need to provide dynamic data you might also want to use dynamic pages and then maybe not cache with nextjs, instead use cloudflare or directly redis for your db (if you using any DB)
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
This is api endpoint, client side fetches it separately from main page data. This is why it might be used with big delays in between.
And while fully dynamic data is nice, I want to cache it for short time because it uses external api.
And while fully dynamic data is nice, I want to cache it for short time because it uses external api.
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall This is api endpoint, client side fetches it separately from main page data. This is why it might be used with big delays in between.
And while fully dynamic data is nice, I want to cache it for short time because it uses external api.
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
why don't you call the external api directly from your client? Why does your external api does not have any cache? Or it have any?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
It needs auth, so credentials are stored on server. Plus it is public data, so everyone gets same response for same request. No point in hitting api multiple times within few minutes
No idea about cache, it is google calendar api.
No idea about cache, it is google calendar api.
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall It needs auth, so credentials are stored on server. Plus it is public data, so everyone gets same response for same request. No point in hitting api multiple times within few minutes
No idea about cache, it is google calendar api.
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
hmm ok. Can't you handle it with a clientside cache? Like requesting your route handler from the client and the client caches it. Then you revalidate more than 7 days times
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
Client side cache means every visitor still makes request at least once to get potentially same result. Which is perfect situation for caching on server side for few minutes in case of burst visits.
But then next visitor may come many days later after previous and would get super stale data
But then next visitor may come many days later after previous and would get super stale data
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall Client side cache means every visitor still makes request at least once to get potentially same result. Which is perfect situation for caching on server side for few minutes in case of burst visits.
But then next visitor may come many days later after previous and would get super stale data
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
yea, you can even put it on revalidation time of 10 minutes, to hold up against small burst and cache it on the clientside to cache on the client for one client. To perfect match
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
But then how to invalidate server cache after 10 minutes without somebody requesting stale data first?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall But then how to invalidate server cache after 10 minutes without somebody requesting stale data first?
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
yo can't. But then you have at least 10 minutes old data. If you want fully dynamic data, then it need to be a fully dynamic route. The caching then need to be handled somewhere else
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
How would you rate chances of this being implemented after feature request?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall How would you rate chances of this being implemented after feature request?
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
I don't think that basic functionality will be changed
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Australian Freshwater Crocodile
Next.js should’ve called it “invalidate” instead of “revalidate” since what it’s doing is marking it as stale, needs to fetched again in next Request instead of actually purging the cache for that next request to get the latest data
Name would be more descriptive at least, imo, unless “invalidate” and “revalidate” mean the same thing
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
I made feature request for it.
Come read it and share your thoughts if you think it is good
https://github.com/vercel/next.js/discussions/76325
Come read it and share your thoughts if you think it is good
https://github.com/vercel/next.js/discussions/76325
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Large oak-apple gall I made feature request for it.
Come read it and share your thoughts if you think it is good
https://github.com/vercel/next.js/discussions/76325
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
Mallow bee
There might be a misconception here, the stale-while-revalidate pattern is for exactly this. If you have an SWR time of 5 minutes, and the data is 4 minutes old, it will show the data while it refetches. If the data was 6 minutes old, it will fetch before showing the data
The scenario of coming back after a week and seeing stale data suggests that either the SWR time is too high or it's not working at all
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Large oak-apple gallOP
Word "stale" implies it first serves stale data anyway, no?
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
Mallow bee
yes for a limited time
there's two general timeouts, the TTL, which is the time after fetching that it becomes stale
and the SWR which is the time AFTER it's been stale that it's still ok to serve (while it revalidates)
so if you have a ttl of 5 and an swr of 5, a user might get data at most 10 minutes out of date
requests between minutes 0 and 5 serve from cache without triggering revalidation
requests between minutes 5 and 10 serve from cache while revalidating the cache in the background
requests after minute 10 will only serve after it fetches fresh data