Description
🐛 The bug
Creating a bare Nuxt project with npx nuxi@latest init project
and starting it with npm run dev
causes severe memory leak (most of the time). This happens on Windows with Node v22+. This happens on a bare Nuxt starter with no additional Nuxt modules or npm packages added. Importantly, the memory leak occurs without any incoming requests happening or the app open in a browser. You only need to npm run dev
after doing the nuxi project init and it will start leaking immediately. This is going to be a pain in the ass because I noticed it usually doesn't happen on the first run of npm run dev
but if you stop the dev server and run the command again it will happen (you know you have it when the CPU is high and the memory starts incrementing).
I believe this is different than nuxt/nuxt#30164 as that is in a built project with requests.
Observations:
- It does not leak when building and running
npm run preview
. - Requests to the dev server are not needed to leak memory.
- Disabling devtools prevents the memory leak.
- It does not leak every time the dev server is started, maybe 10% of the time it will run normally on the bare project.
- It also leaks with Node v22.12.0 in addition to v23.3.0.
- Abnormally high CPU usage is occurring.
- It ticks up by 2.7-2.9 MB per second.
Proof
These images were taken after enabling/disabling Nuxt devtools and running npm run dev
and waiting for exactly 5 minutes.
Snapshots
These make it seem like there is something with \node_modules\unstorage\node_modules\readdirp\index.js
and/or are-we-there-yet\node_modules\readable-stream
. But also defineNuxtSchema
.
Here's how I did this:
npx nuxi dev --inspect
with devtools disabled- Open Chrome and go to
chrome://inspect
and inspect the Node project - Let it run 5 minutes, collect garbage and take another snapshot (Snapshot 1, control)
- Edit
nuxt.config.ts
and enable devtools, let it restart with HMR - Let it run 10 minutes, then collect garbage and take another snapshot (Snapshot 2)
- Let it run 10 more minutes, then collect garbage and take final snapshot (Snapshot 3)
Snapshot 2 vs Snapshot 3 (devtools enabled short vs longer leak)
Full reproduction
Since I don't think stackblitz is going to show this issue:
npx nuxi init@latest project
cd project
npm run dev
- Quit the process and re-run
npm run dev
- Observe memory leak
npx nuxi devtools disable
npm run dev
- Observe no memory leak
🛠️ To reproduce
https://stackblitz.com/edit/github-4exzk3tl
🌈 Expected behavior
devtools should not be causing a memory leak in a bare project created with npx nuxi@latest init project
ℹ️ Additional context
npx nuxi info
- Operating System: Windows_NT
- Node Version: v23.3.0
- Nuxt Version: 3.14.1592
- CLI Version: 3.16.0
- Nitro Version: 2.10.4
- Package Manager: [email protected]
- Builder: -
- User Config: default
- Runtime Modules: -
- Build Modules: -
Full nuxt.config.ts (devtools enabled)
// https://nuxt.com/docs/api/configuration/nuxt-config
export default defineNuxtConfig({
devtools: {
enabled: true,
timeline: { enabled: true },
},
compatibilityDate: '2024-11-01',
})
Full nuxt.config.ts (devtools disabled)
// https://nuxt.com/docs/api/configuration/nuxt-config
export default defineNuxtConfig({
devtools: {
enabled: false,
timeline: { enabled: true },
},
compatibilityDate: '2024-11-01',
})