Skip to content
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

10.0.8 next/image high memory use #22925

Closed
scttcper opened this issue Mar 10, 2021 · 18 comments · Fixed by #23077
Closed

10.0.8 next/image high memory use #22925

scttcper opened this issue Mar 10, 2021 · 18 comments · Fixed by #23077
Assignees
Milestone

Comments

@scttcper
Copy link

scttcper commented Mar 10, 2021

What version of Next.js are you using?

10.0.8

What version of Node.js are you using?

14.15.4

What browser are you using?

chrome

What operating system are you using?

macOS

How are you deploying your application?

next start

Describe the Bug

With v10.0.8 on pages with lots of next/image components seeing much higher memory use compared to 10.0.7. Possibly related to #22253

Expected Behavior

less memory use

To Reproduce

checkout branch nextjs-leak https://github.com/scttcper/xmplaylist/tree/nextjs-leak
run yarn && yarn build && cd frontend && npx next start

open localhost:3000 and just refresh the root/home page a few times (the backend is not required for this page). Memory should shoot up to 400-500mb. In production this was consuming 2gb (all memory available)

Production version is - https://xmplaylist.com/ you can see the home page has a good set of images.

@scttcper scttcper added the bug Issue was opened via the bug report template. label Mar 10, 2021
@scttcper scttcper changed the title next/image 10.0.8 next/image high memory use Mar 10, 2021
@frigus02
Copy link

We experience this as well. We use Next.js for a shop-like website, which has 60-100 images per page. After updating Next.js from 10.0.7 to 10.0.8 our memory usage jumped from ~600MB to ~3.7GB

With 10.0.7:

grafik

With 10.0.8:

grafik

We reverted to 10.0.7 and memory usage is back to ~600MB.

We can't say for sure if this is related to images. But we did see a general increase in response time for /_next/image URLs together with the memory increase while other routes didn't show an increased response time.

@jnv
Copy link

jnv commented Mar 11, 2021

I can confirm the same issue. We run our app in container with limited memory and since update to 10.0.8 we started to get regular out-of-memory crashes even though there were just two images going through /_next/image endpoint – 256M were not sufficient. In our case it was easier to avoid use of next/image altogether.

@shuding shuding self-assigned this Mar 11, 2021
@underfisk
Copy link

It's also happening to me, more than this issue but its one critical issue even on the optimization of the images, its suffering with response time

@r3na
Copy link

r3na commented Mar 11, 2021

+1

@muntasirsyed
Copy link

muntasirsyed commented Mar 12, 2021

10.0.8 was supposedly supposed to fix this issue by switching out the sharp library for a wasm equivalent but it's made it even worse. We've had to rollback all usage of next/image now in production unfortunately.

It was consuming literally all memory available on our ec2 instances.

@timneutkens timneutkens added kind: bug and removed bug Issue was opened via the bug report template. labels Mar 12, 2021
@timneutkens timneutkens added this to the iteration 17 milestone Mar 12, 2021
@imhuynq

This comment has been minimized.

@shuding
Copy link
Member

shuding commented Mar 12, 2021

We've identified the cause and are working on a fix, but it would be helpful if you can share more info for this! I.e. number of CPU cores, average image size, memory increased after upgrading, etc.

@karlhorky
Copy link
Contributor

I know @Thoud was experiencing this the other day, deploying his Next.js bootcamp project to the Heroku free plan...

@chemicalkosek
Copy link
Contributor

chemicalkosek commented Mar 14, 2021

Having the same thing.
Next.js website deployed to dokku container.
2cpu Digital Ocean droplet.

There are only two Image component images (original image sizes approx 300kb and 20kb)
Each website reload (when the 60 seconds image cache ends) adds 100-200MB to memory usage.
I noticed by having alerts from netdata about low memory on server.
At that point the affected nextjs website had 2.4GB memory usage.

After reverting to 10.0.7 much better, but still more memory usage than much bigger next.js apps without Image component.
Still rises by about 20-25MB on each reload. I will see how it goes.
Edit: I think it has stabilized at around 260MB

2021-03-14_20-23

@kodiakhq kodiakhq bot closed this as completed in #23077 Mar 16, 2021
kodiakhq bot pushed a commit that referenced this issue Mar 16, 2021
This PR upgrades `jest-worker` and `jest-cli` to the latest pre-release version, also removed `jest-circus` which is included in Jest by default. `jest-worker@next` includes a fix for memory leak that we need (jestjs/jest#11187). 

Fixes #22925. This will also improve the OOM issue for `next dev` #15855.
@fostyfost
Copy link

fostyfost commented Mar 17, 2021

Hi!
@Timer @timneutkens
Why does #23077 close this and #20915 issues? This may be a mistake. This issue is still relevant. You need to open this issue again.

@timneutkens
Copy link
Member

@fostyfost it's fixed on the canary line. Please try installing next@canary.

@fostyfost
Copy link

@timneutkens please tell me which commit fixes this issue?

@timneutkens
Copy link
Member

#23077

@Trallp
Copy link

Trallp commented Mar 17, 2021

@timneutkens Just built and started on my mac (not m1) the same project and opened the same page with ~10 next/image images

10.0.7 ~ 118 MB:
10.0.7

10.0.10-canary.2 ~ 826 MB:
10.0.10-canary.2

Sorry for Activity Monitor but even here the problem is obvious

kodiakhq bot pushed a commit that referenced this issue Mar 18, 2021
As stated in #23157, this PR merges all the operations into 1 worker thread (`processBuffer` in `impl.ts`) and only pass a list of operation names and args into the worker. This should improve the speed and memory usage of next/image.

Fixes #23157. X-ref: #22925.
@jakubjo
Copy link

jakubjo commented Mar 20, 2021

I can confirm this. I had the same memory issues when deployed to production. Even using next@canary.
Downgrade to next.js 10.0.7 has resolved the issues. Ubuntu 20.04.

@gu-stav
Copy link

gu-stav commented Mar 22, 2021

@shuding Unfortunately you good work doesn't fix the issue for me (even on v10.0.10-canary.7). It still exceeds 1960MB, where as it uses much less memory in 10.0.7 (230MB).

@karlhorky
Copy link
Contributor

I guess the new issue tracking this problem is over here: #23189

flybayer pushed a commit to blitz-js/next.js that referenced this issue Apr 29, 2021
This PR upgrades `jest-worker` and `jest-cli` to the latest pre-release version, also removed `jest-circus` which is included in Jest by default. `jest-worker@next` includes a fix for memory leak that we need (jestjs/jest#11187). 

Fixes vercel#22925. This will also improve the OOM issue for `next dev` vercel#15855.
flybayer pushed a commit to blitz-js/next.js that referenced this issue Apr 29, 2021
As stated in vercel#23157, this PR merges all the operations into 1 worker thread (`processBuffer` in `impl.ts`) and only pass a list of operation names and args into the worker. This should improve the speed and memory usage of next/image.

Fixes vercel#23157. X-ref: vercel#22925.
@balazsorban44
Copy link
Member

This issue has been automatically locked due to no recent activity. If you are running into a similar issue, please create a new issue with the steps to reproduce. Thank you.

@vercel vercel locked as resolved and limited conversation to collaborators Jan 28, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.