-
Notifications
You must be signed in to change notification settings - Fork 4.4k
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
transport: reduce memory usage for small reads in server handler #7972
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #7972 +/- ##
==========================================
- Coverage 82.28% 82.07% -0.22%
==========================================
Files 381 381
Lines 38539 38546 +7
==========================================
- Hits 31712 31636 -76
- Misses 5535 5591 +56
- Partials 1292 1319 +27
|
Hi, @lqs, thanks for sending this PR. Do you have benchmarks showing the effect of this optimization? We are incurring an extra copy when the bytes read are <= 4KB. We need to decide if the time spent is worth the memory savings. |
Hi, @arjan-bal, thanks for the feedback. Most requests in normal cases are only a few dozen bytes, so the extra copy has almost no impact. Even in the worst case, where each frame is exactly 4KB, the copy would add about 200ns on modern hardware. If this is a concern, we could reduce the threshold, for example, only copying when the data is smaller than 256 bytes. |
gRPC needs to work well with workloads of all types, large and small messages. If optimizing for specific workloads causes negative impact in others, we need to wight the benefits carefully. @dfawley would like to get your thoughts here. |
If we want to reduce the impact on other workloads, we could lower the copy threshold further (e.g., 32 bytes) or start with smaller buffers and grow them as needed. Would these approaches work better? |
Hi @lqs, sorry for the delay, Doug is on vacation and should be back next week. I would like to get his input on this change. |
Generally speaking, these buffers should be short-lived:
That said, if you are queuing up lots of small messages on one stream, then this could potentially add up. Can we use |
Hi @dfawley |
This pull request optimizes memory usage in the
HandleStreams
method. Previously, a 16KB buffer (http2MaxFrameLen) was allocated for each request and held until the call completed, which caused unnecessary memory waste when handling long-running requests with many concurrent clients, as memory usage remains high throughout the lifetime of the requests.Changes
serverHandlerTransport.HandleStreams
, small reads (n < http2MaxFrameLen/4) are now copied into smaller buffers, allowing the larger buffers to be returned to the pool.