-
-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Memory Leak #281
Comments
Will need some reproduction details |
We have a lot of code generated, it is impossible to have a minimal playback environment |
Without a reproduction, there isn't much I can do. This screenshot just shows it hit a memory limit while running this line, which doesn't mean that's where a memory leak is. There's no way to confirm if Unhead is the problem or if downstream code implementing it, which seems more likely given this is the first time a memory leak issue has been opened and knowing how the API is designed. |
There could be some truth to this report. As you know, @harlan-zw, I'm new to debugging memory overflows, but poking around led me to the function unhead/packages/unhead/src/createHead.ts Line 48 in b2bc253
in which there are two suspects: |
While testing for memory leaks in Whatever seemed to be leaking did so at a low rate, unless someone manages to reproduce it, I wouldn't worry too much about it. 😅 |
Thank you for your investigation @BobbieGoede! Some great work on @nuxtjs/i18n 👏 |
I investigated too 😭 😂 I have one or two other theories on suspect code, maybe we can have a look together in the coming days @harlan-zw or @BobbieGoede? If you have time next week, we could meet on Discord to stop the leak 🧹 |
Just saw and tested that nuxt-modules/i18n#2621 is also a great fix 🔥 🚀 From the looks it seems that the only directly noticeable leak left is on me in my project. So no need for a call rn, but I may get back to that if I find anything else. Thank you all for the good work! |
I can explain better than the opener of the bug. He is right. The leak is in the |
There should only be a single instance of Vue kept in memory, it's not freed as you correctly identified. It shouldn't be stacking though, your screenshot doesn't show that it is afaik? |
BTW, while I was searching for what could be leaking memory in the i18n module I often saw this pattern ( I guess the primary reason for doing this is to reduce the build size, but a side effect is that we don't see these keys when debugging memory (which I have only done on a production build). Since unhead does not use this pattern, and it uses some memory, it will be one of the first things you'll see when debugging which doesn't necessarily mean that it is leaking. |
This seems to be one of the largest memory leaks that's preventing us at Openverse from migrating to Nuxt 3. Even after I removed all of the Here's the PR for migrating to Nuxt 3 that is, unfortunately, unusable, due to memory leaks. |
Looks like a vue-router stack? $head is a singleton on the vue VM (like globalProperties), so not sure what you're showing here exactly. Not to say there isn't an issue, but this doesn't help me identify anything from Unhead's side. Also, see comment above. This is something I do want to take a deeper look into in any case but I'm currently limited with time so unless more people are reporting memory leak issues with Nuxt / Unhead then it's a low priority as it's going to be a lengthy investigation. |
@obulat This won't fix the memory leak in your PR (I checked) but likely reduces it, it could still be the i18n module or unhead or both, I'll look into it some more when I have the time. |
Thank you for looking into our repo, @BobbieGoede ! I'll try the edge version. |
I did some testing with clinic.js and was not able to replicate any sort of memory leak. This is with ~500 connections doing ~5k requests x2 on a Nuxt app. Will leave this issue open in case anyone has any further research they can share. (I tried testing with other clinic.js tools but it was failing). |
Also I see many strings not getting garbage collected, megs and megs of ram not being cleared. Up for a call if you want to check this out @harlan-zw |
Can you include reproduction? On our large project with heavy unhead usage (including not-so-official solutions in our plugins) our memory stays at ~400MB without significant increases. I also noticed unhead growing in size, but GC seems to be working for us |
To anyone experiencing this issue, I would ask that you check in your package-lock.json or yarn.lock that your vue is up to date, (it might not be because of a bug in yarn that does not update sub deps when targeting update of a single package so if only nuxt is a direct dep and is targeted for upgrade, vue will not upgrade) Please check that you are at least on 3.5.7 which fixes 3 memory leak issues, and if you are not, then please try again after upgrading and report back |
Managed to trigger the memory leak and 100% concisely. I am doing some workaround here in Nuxt to dodge Nuxt dedupe bcs my object is quite quite large. For the info it was working for some time and didn't cause any memory leaks but i buffed the deps to latest and now it's exploding. I am using huge payloads od 300kb so as you know the server fails in seconds. I think basically what happens after Vue SSR suspense never gets resolved. Just my theory
I can workaround around this issue easily but still this is the common use case of How not to use useHead that works from version to version. Just ping me if you need any more data on the issue but schema, nuxt, vue, unhead are used in unhoisted pnpm monorepo. PS. as a user I would expect the default behavior of what I am doing here to "not work" in non failing way: "produce a lot of undefineds" but I would not like to produce a memory leak. |
@Xenossolitarius Does it make any difference if you move |
Not really. I moved it all over the place but this is not supported anymore. Its positioned after the primary await in app.vue |
Environment
Linux
v20.5.1
3.8.2
3.10.0
2.8.0
npm@9.8.0
-
-
-
-
Reproduction
When i crawled our web, crashes by memory leak
Describe the bug
When i crawled our web, crashes by memory leak
Additional context
No response
Logs
No response
The text was updated successfully, but these errors were encountered: