I use vercel to deploy my next+prismic project and i'm having the "Ref not found. Ensure you have the correct ref and try again." error only on pages that use the ISR Functions and when i'm visiting the ISR pages i get the " Application error: a server-side exception has occurred (see the server logs for more information)." message. Pages that use generateStaticParams have no issue and the builds always complete succesful.
If i revoke the access token and add a new one and redeploy the same deployment that failed, it will work perfectly, but then if i commit again the new deployment will have the above error again.
I have tried to change my prismic api to public and to add the VERCEL_FORCE_NO_BUILD_CACHE variable but nothing changed, also locally everything works correctly.
Have anyone faced the same issue?
Here is the entire error i get in vercel:
q [Error]: Ref not found. Ensure you have the correct ref and try again. Master ref is: xxx
at z.fetch (/var/task/.next/server/chunks/757.js:1:11855)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async z.getFirst (/var/task/.next/server/chunks/757.js:1:5114)
at async z.getSingle (/var/task/.next/server/chunks/757.js:1:6099)
at async h (/var/task/.next/server/app/xxx/page.js:1:16325) {
url: 'https://xxx',
response: {
type: 'api_notfound_error',
message: 'Ref not found. Ensure you have the correct ref and try again. Master ref is: xxx'
}
}
Hi @john-mantas. I wasn't sure about this so I asked some of my colleagues about it. Here's the response I received:
It sounds like they are using the App Router since they refer to generateStaticParams. The App Router no longer has a concept of "incremental static regeneration," and instead has on-demand revalidation. Let's ask to confirm that they are using on-demand revalidation.
They likely do not have caching set up correctly. "Ref not found" typically happens when a cached /api/v2 request returns an expired ref. The fact that everything works locally, where they may have caching disabled, points to a caching misconfiguration.
Their @prismicio/clientcreateClient() calls should contain this recommended fetchOptions:
Hi @Levi. I do use the App Router and by "ISR Functions" (this is how it was called in the vercel dashboard) i mean routes that do not export a generateStaticParams function.
My createClient() contains the same fetchOptions as the minimal starter repo and also my /api/revalidate is the same.
Does the revalidation endpoint should be called with a webhook anytime a document is published/unpublished or should it be called somehow before the route gets generated?
I haven't set up any webhooks in prismic yet and for now i'm just rebuilding the project only with my git commits.
Also, does the master ref change when a document is published or unpublished?
PS. I'm adding some screenshots from the dashboard to better understand which pages i'm talking about, which btw today has been changed and the "ISR Functions" includes only the statically generated routes instead of the on-demand that it was when i opened this topic. The problem occurs at the "/photos" routes.
@Levi Thank you for the informations, i hadn't read the guide you posted.
It just works now, i don't know if either vercel or prismic changed something, but it just started working without me changing anything and it seems that still works after multiple commits and deploys i have done the last 2 days.
I'm keeping an eye on it and i will use the revalidation webhook if this error comes up again.
When I get the errors you are mentioning, I find that clearing my .next folder does the trick. I run rm -rfv ./.next and then when I run bun dev or bun run build, all is good (sub npm/yarn/etc for bun)
For this specific page I have decided to opt out of slice zone and just using my own html for it. Everything works fine in development but works in production
Hi I am facing this issue too. We can just temporarily change the default prismic caching from 'force-cache' into 'no-store'. After the cache cleared we can change it back to 'force-cache'. const client = prismic.createClient(repositoryName, { routes, fetchOptions: process.env.NODE_ENV === 'production' ? { next: { tags: ['prismic'] }, cache: 'no-store' } : { next: { revalidate: 5 } }, ...config, });
I had the same issue on a large website today. I had to go to Vercel - click on the website - settings and then purge the cache. Please note that re-deployment did not fix the issue.
It doesn't matter if the cache is reinvalidated via API, it seems like Prismic is caching something else that gets stuck in the /.next cache, that is related to the master ref.
Any clue what it might be, and why the master ref keeps changing from time to time which breaks things?
the createClient function uses this by default if I don't override the fetchOptions:
{ next: { tags, revalidate: 60 * 60 * 2 } }
Could it be that createClient caches the response from the API endpoint in NextJS, causing it to fetch outdated ref? I went through your troubleshooting article, but it didn't discuss this issue.
@Phil I looked into the /.next/cache/fetch-cache folder which has various files made for each request, and each file contains the fetch request made for the page and it includes the master ref in the URL.
If the fetch request for the page is cached, then NextJS should just get the data from cache and make no API call to Prismic (even if the master ref has changed), which is all fine.
So lets say the page is reinvalidated, that file should disappear based on the tag or reinvalidation time, and NextJS should make a new request to fetch the page. I assume it will re-fetch https://perlan.cdn.prismic.io/api/v2 to get a new master ref? If not, then that would be a problem.
I'm trying to figure out why the issue started happening out of the blue, since the website has been running for several months without any issues, and reinvalidation has worked like magic.