AWS
Troubleshooting

Debug mode

OpenNext can be executed in debug mode by setting the environment variable OPEN_NEXT_DEBUG=true.

This will output A LOT of additional logs to the console.This also disable minifying in esbuild, and add source maps to the output. This can result in code that might be up to 2-3X larger than the production build. Do not enable this in production

OPEN_NEXT_DEBUG=true npx open-next@latest build

Cannot find module next

You might stumble upon this error inside cloudwatch logs: Cannot find module 'next'. It is likely that you are in a monorepo and you have several lock files. Just make sure that you have a single lock file in the root of your project.

Reducing bundle size

Next might incorrectly include some dependencies in the bundle. To remove them you can use this configuration inside next.config.js:

experimental: {
    outputFileTracingExcludes: {
      "*": ["node_modules/the-unwanted-package"],
    },
  },

Also you should not add sharp as a dependencies unless absolutely necessary, the image optimization already has it's own version of sharp.

Patch fetch behaviour for ISR. Only for next@13.5.1+

If you use ISR and fetch in your app, you may encounter a bug that makes your revalidate values inconsistent. The issue is that it revalidates using the lowest revalidate of all fetch calls in your page, regardless of their individual values. To fix this bug, you need to modify the fetch function in your root layout component with the following code snippet

export default function RootLayout() {
  const asyncStorage = require('next/dist/client/components/static-generation-async-storage.external');
  //@ts-ignore
  const staticStore =
    (fetch as any).__nextGetStaticStore?.() ||
    asyncStorage.staticGenerationAsyncStorage;
  const store = staticStore.getStore();
  store.isOnDemandRevalidate =
    store.isOnDemandRevalidate && !(process.env.OPEN_NEXT_ISR === 'true');
  return <>...</>;
}

Access Denied errors on routes during page refresh and direct URL access

If you are refreshing a dynamic/static route or going to that route directly from an URL. Like this route f.ex: /profile/[userId]/[id], and you are getting an Access Denied error in XML:

<Error>
   <Code>AccessDenied</Code>
   <Message>Access Denied</Message>
   <RequestId>R4E6T9G2Q1S0Z5X8</RequestId>
   <HostId>S7h9F3g2T0z5K8d6A2s1W4x3C7v8B9m2L0j3K4i7H8g9F0r3A5q8w9E8r7t6Y5h4U3i2O1p0</HostId>
</Error>

This can also happen in app router when a client navigates via NextJS <Link> component.

The issue might be that your having a folder or file in your public directory with an overlapping between the name and your route. In this case, you should rename that to something else.

cannot find module './chunks/xxxx.js' error

Dynamic imports in instrumentation.ts will cause this error at runtime. Remove dynamic imports to resolve.

Sentry server side setup

The config recommended by Sentry docs uses dynamic imports in instrumentation.ts, which causes the above error.

Here's a working Sentry config which resolves the error:

instrumentation.ts

import * as Sentry from '@sentry/nextjs';
import { initSentry } from '../sentry.server.config';
 
export const onRequestError = Sentry.captureRequestError;
 
export async function register() {
  initSentry(process.env.NEXT_RUNTIME as 'nodejs' | 'edge');
}

sentry.server.config.ts

import * as Sentry from '@sentry/nextjs';
 
export const initSentry = (runtime: 'nodejs' | 'edge') => {
  Sentry.init({
    dsn: 'https://...',
 
    //...rest of your config
  });
};