-
Notifications
You must be signed in to change notification settings - Fork 4.9k
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
[Heartbeat] Improve browser heap memory usage #32317
Merged
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This patch fixes a potential memory leak, and also dramatically increases heartbeat's efficiency WRT parsing the JSON output of the synthetics agent. It does appear that we don't close all the readers used by `scanToSynthEvents` which this patch fixes. I did observe heap growth w/o this patch over a short timescale. I'll run longer tests to confirm soon. Additionally, we waste a lot of memory / allocations buffering lines of JSON, which can be quite large. The `json` decoder can actually parse ndjson very efficiently itself. Switching to using it totally altered the heap profile, removing the top user of memory `scanToSynthEvents`.
andrewvc
added
enhancement
Team:obs-ds-hosted-services
Label for the Observability Hosted Services team
v8.4.0
labels
Jul 12, 2022
botelastic
bot
added
needs_team
Indicates that the issue/PR needs a Team:* label
and removed
needs_team
Indicates that the issue/PR needs a Team:* label
labels
Jul 12, 2022
Collaborator
Pinging @elastic/uptime (Team:Uptime) |
emilioalvap
approved these changes
Jul 18, 2022
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, tested in parallel with 8.4.0-SNAPSHOT
and saw lower memory allocation per monitor.
chrisberkhout
pushed a commit
that referenced
this pull request
Jun 1, 2023
This patch does not fix a potential memory leak as mentioned on the forum, but does dramatically increases heartbeat's efficiency WRT parsing the JSON output of the synthetics agent. It does appear that we don't close all the readers used by scanToSynthEvents which this patch fixes. I did observe heap growth w/o this patch over a short timescale, but that's almost certainly not a resource leak, those readers should have been auto closed when exec ended anyway. We do however waste a lot of memory / allocations buffering lines of JSON, which can be quite large. The json decoder can actually parse ndjson very efficiently itself. This also lets us use a smaller buffer for stdout/stderr buffering. We had allocated a larger one prior to handle the base64 image data passed by the agent.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This is a draft in WIP until I can confirm the leak.This patch
fixesdoes not fix a potential memory leak as mentioned on the forum, but does dramatically increases heartbeat's efficiency WRT parsing the JSON output of the synthetics agent.It does appear that we don't close all the readers used by
scanToSynthEvents
which this patch fixes. I did observe heap growth w/o this patch over a short timescale, but that's almost certainly not a resource leak, those readers should have been auto closed when exec ended anyway.We do however waste a lot of memory / allocations buffering lines of JSON, which can be quite large. The
json
decoder can actually parsendjson
very efficiently itself. This also lets us use a smaller buffer for stdout/stderr buffering. We had allocated a larger one prior to handle the base64 image data passed by the agent.Switching to using it totally altered the heap profile, removing the top user of memory
scanToSynthEvents
.Heap profile before
Heap profile after
Checklist
CHANGELOG.next.asciidoc
orCHANGELOG-developer.next.asciidoc
.Author's Checklist
How to test this PR locally
Run with some browser monitors of your choice. To profile I'm using the following commands: