question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Memory leak on SSR after upgrading from 2.x to 3.3.13

See original GitHub issue

Recently decided to upgrade apollo client from 2.6 to 3.3.13. After releasing it to production we saw huge memory usage increase on a server side. Rolling back to the old 2.6 version solved the problem.

Here is what happened in production while switched to 3.3.13 (tried to solve memory leak problem), gave up after 3 days and rolled back to 2.6: memory-leak-edited

Here is what we saw in the heapdumps (comparison view, filtered objects that were not deleted):

heapdump-deleted-o

Seems like a lot of “Entry” instances are not garbage collected (deleted 0). Here is a dependency tree, maybe someone can help to see where the problem is:

entry

Any help will be appreciated 🙏

Heapdumps:

Shortly about our setup:

  • SSR (Node.js, React, apollo)
  • Server side code is bundled with webpack

What we have tried:

  • resultCaching:false config for the inmemory cache
  • Manuall call client.stop() client.clearStore after each request.
  • Removed all readFragment calls.
  • Different node.js versions 12.8, 14.16
  • Increased max old space size (heap size)
  • Downgrade to apollo 3.1.3

Versions

  • OS - alpine3.11
  • @apollo/client - 3.3.13
  • node.js - 14.16.0
  • react - 16.8.2
  • webpack 4.35.2
  • graphql": 15.5.0
  • graphql-tag": 2.12.0

Issue Analytics

  • State:open
  • Created 2 years ago
  • Reactions:40
  • Comments:43 (9 by maintainers)

github_iconTop GitHub Comments

7reactions
AlexMostcommented, Sep 20, 2021

Tried fetchPolicy: no-cache this one reduces memory and CPU consumption significantly, but memory leak is still present 😢

Currently, we have test setup with apollo3 with mirrored traffic from production, so I can check any hypothesis very quickly, any suggestion or help will be much appreciated!

apollo-update

5reactions
matthewnoursecommented, Mar 2, 2022

The problem for us was that the stringifyCanon and stringifyCache globals in object-canon.js grow without bound even when caching is disabled. The fix was to call ApolloClient.clearStore whenever we create the client:

export const getApolloClient = () => {
  const client = new ApolloClient({ /* whatever config you need  here */ });

  return client.clearStore().then(() => client);
}
Read more comments on GitHub >

github_iconTop Results From Across the Web

Learn How to Debug the Cause of Memory Leak in SSR
After migrating a project in my charge to SSR, it made a sharp increase in heap memory and the Nodejs server was dead...
Read more >
GitHub statistics for 3.5.2 (May 02, 2022) - Matplotlib
x (Raised macosx memory leak threshold). PR #22961: Raised macosx memory leak threshold. PR #22945: FIX: Handle no-offsets in collection datalim.
Read more >
Hunting memory leaks in a server side rendered React ...
If you are using server side rendering (SSR) for your React application, you surely faced some issues at times. Even if you choose...
Read more >
3 Troubleshoot Memory Leaks - Java - Oracle Help Center
After a garbage collection, if the Java application spends more than approximately 98% of its time performing garbage collection and if it is...
Read more >
How to Detect and Fix Memory Leaks With Chrome DevTools
You have 2 free member-only stories left this month. ... Performance Timeline Record: before and after Memory Leak Fix (animation created by Rakia...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found