Optimizing Your Local Development Environment in Next.js – Speed Up Compilation and Improve Dev Experience

As your Next.js application grows, local development may slow down due to compile-time bottlenecks. This article explores practical strategies to improve performance, including antivirus configuration, Turbopack usage, import hygiene, Tailwind setup, memory optimization, and diagnostic tools like Turbopack tracing.

Next.jsLocal DevelopmentTurbopackCompile PerformanceCompile Performance

~3 min read • Updated Oct 28, 2025

Local Development vs. Production


next dev compiles routes on demand as you navigate, while next build and next start apply production optimizations like minification and content hashing. This makes local development faster and less memory-intensive.


1. Check Your Antivirus


Antivirus software can slow down file access, especially on Windows. Add your project folder to the exclusion list in Microsoft Defender. On macOS, enable developer mode for your terminal using:

sudo spctl developer-mode enable-terminal

Then go to System Settings → Privacy & Security → Developer Tools and ensure your terminal is listed and enabled.


2. Update Next.js and Use Turbopack


Upgrade to the latest version of Next.js to benefit from performance improvements. Turbopack is now the default bundler:

npm install next@latest
npm run dev

To use Webpack instead:

npm run dev --webpack

3. Optimize Imports


Importing entire icon libraries or using barrel files can slow down compilation. Prefer direct imports:

// Instead of:
import { TriangleIcon } from '@phosphor-icons/react'

// Use:
import { TriangleIcon } from '@phosphor-icons/react/dist/csr/Triangle'

Stick to one icon set and avoid mixing multiple sets like pi, md, tb, cg.


4. Tailwind CSS Setup


Ensure your content array in tailwind.config.js is scoped correctly:

module.exports = {
  content: ['./src/**/*.{js,ts,jsx,tsx}'], // Good
}

Avoid scanning node_modules or overly broad paths.


5. Review Custom Webpack Settings


Custom Webpack configs may slow down builds. Consider removing them for local development or switching to Turbopack.


6. Optimize Memory Usage


Large apps may require more memory. Monitor usage and consider splitting modules or using lighter dependencies.


7. Server Components and Data Fetching


Changes to Server Components trigger full page re-renders. Use the experimental serverComponentsHmrCache to cache fetch responses across HMR refreshes.


8. Prefer Local Development Over Docker


Docker on macOS and Windows can slow down HMR due to filesystem access. For best performance:

  • Use npm run dev locally
  • Reserve Docker for production builds
  • If needed, run Docker on Linux or inside a VM

Tools for Diagnosing Performance


Fetch Logging


module.exports = {
  logging: {
    fetches: {
      fullUrl: true,
    },
  },
}

Turbopack Tracing


NEXT_TURBOPACK_TRACING=1 npm run dev

After reproducing the issue, stop the server and run:

npx next internal trace .next/dev/trace-turbopack

View the trace at trace.nextjs.org.


Conclusion


Optimizing your local development environment in Next.js ensures a smoother, faster workflow. By updating dependencies, refining imports, configuring Tailwind properly, and using diagnostic tools, you can reduce compile times and improve your overall developer experience.


Written & researched by Dr. Shahin Siami