~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-terminalThen 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 devTo use Webpack instead:
npm run dev --webpack3. 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 devlocally - 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 devAfter reproducing the issue, stop the server and run:
npx next internal trace .next/dev/trace-turbopackView 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