Get started
Learn how to deploy full-stack (SSR) Next.js apps to Cloudflare Pages.
To create a new Next.js app, pre-configured to run on Cloudflare, run:
npm create cloudflare@latest -- my-next-app --framework=next --platform=pagesyarn create cloudflare my-next-app --framework=next --platform=pagespnpm create cloudflare@latest my-next-app --framework=next --platform=pagesFor more guidance on developing your app, refer to Bindings or the Next.js documentation ↗.
First, install @cloudflare/next-on-pages ↗:
npm i -D @cloudflare/next-on-pagesyarn add -D @cloudflare/next-on-pagespnpm add -D @cloudflare/next-on-pagesThen, add a Wrangler configuration file to the root directory of your Next.js app:
{  "name": "my-app",  "compatibility_date": "2024-09-23",  "compatibility_flags": [    "nodejs_compat"  ],  "pages_build_output_dir": ".vercel/output/static"}name = "my-app"compatibility_date = "2024-09-23"compatibility_flags = ["nodejs_compat"]pages_build_output_dir = ".vercel/output/static"This is where you configure your Pages project and define what resources it can access via bindings.
Next, update the content in your next.config.mjs file.
 import { setupDevPlatform } from '@cloudflare/next-on-pages/next-dev';
/** @type {import('next').NextConfig} */const nextConfig = {};
 if (process.env.NODE_ENV === 'development') {   await setupDevPlatform(); }
export default nextConfig;These changes allow you to access bindings in local development.
Next.js has two "runtimes" ↗ — "Edge" and "Node.js". When you run your Next.js app on Cloudflare, you can use available Node.js APIs — but you currently can only use Next.js' "Edge" runtime.
This means that for each server-rendered route — ex: an API route or one that uses getServerSideProps — you must configure it to use the "Edge" runtime:
export const runtime = "edge";Add the following to the scripts field of your package.json file:
"pages:build": "npx @cloudflare/next-on-pages","preview": "npm run pages:build && wrangler pages dev","deploy": "npm run pages:build && wrangler pages deploy"- npm run pages:build: Runs- next build, and then transforms its output to be compatible with Cloudflare Pages.
- npm run preview: Builds your app, and runs it locally in workerd ↗, the open-source Workers Runtime. (- next devwill only run your app in Node.js)
- npm run deploy: Builds your app, and then deploys it to Cloudflare
Either deploy via the command line:
npm run deployyarn run deploypnpm run deployOr connect a Github or Gitlab repository, and Cloudflare will automatically build and deploy each pull request you merge to your production branch.
Optionally, you might want to add eslint-plugin-next-on-pages, which lints your Next.js app to ensure it is configured correctly to run on Cloudflare Pages.
npm i -D eslint-plugin-next-on-pagesyarn add -D eslint-plugin-next-on-pagespnpm add -D eslint-plugin-next-on-pagesOnce it is installed, add the following to .eslintrc.json:
{  "extends": [    "next/core-web-vitals",    "plugin:eslint-plugin-next-on-pages/recommended"  ],  "plugins": [    "eslint-plugin-next-on-pages"  ]}Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark