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

Sub-optimal memory leak capabilities with Pyroscope Java agent #94

Open
Nerja opened this issue May 8, 2023 · 0 comments
Open

Sub-optimal memory leak capabilities with Pyroscope Java agent #94

Nerja opened this issue May 8, 2023 · 0 comments

Comments

@Nerja
Copy link

Nerja commented May 8, 2023

Hi,

I’m trying to use Grafana Pyroscope to find a simulated memory leak in a small example program. I have two methods called leak() and noLeak() where the leak() method saves data to a Set every time it is called and noLeak() only allocates some memory that will be garbage collected. When I use Async Profiler (2.9) locally with the –live option I see that the leak() method is “leaking” memory. When I try to use the Pyroscope agent instead (io.pyroscope:agent:0.11.3) I don’t see it nearly as clearly.
async-large
pyroscope-large
pyro-zoom
async-zoom

I used the following configuration when setting up the Pyroscope Java agent:

Config config = new Config.Builder()
                .setApplicationName("leaktest-1")
                .setFormat(Format.JFR)
                .setServerAddress("http://localhost:4040/")
                .setUploadInterval(Duration.ofSeconds(10))
                .setProfilingEvent(EventType.ALLOC)
                .setAllocLive(true)
                .build();

When I run the async profiler, locally, for 60s or more then I can easily see the memory leak. When I run the async profiler for 10s or less than I observe the same behavior as I see with Pyroscope.
async-10

I also tried to change the upload interval of the Pyroscope Java agent to 60s, but I am still not able to see the memory leak in a good way.

Slack thread: https://grafana.slack.com/archives/C049PLMV8TB/p1683294542388929

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant