Improve performance of small websocket messages [jetty-10.0.x] #4561
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.
Hi, Jetty Maintainers!
We've noticed in our tests based on jetty
9.4.26.v20200117
that a significant amount of CPU time is spent inSimpleBinaryMessage#appendFrame
, and after running an allocation profiler, that the method is responsible for the majority of allocations (65% of all in our case).After having a closer look, it seems like even in the case of very small messages, the underlying method always allocates 65535 bytes. In our usage profile, the majority of the messages are very small, often than 100 bytes, and it seems like it's possible only to allocate the amount of memory needed in that case.
Since websocket classes were changed in jetty 10, this PR modifies
ByteArrayMessageSink.java
rather than the currentSimpleBinaryMessage.java
. However, if the PR looks good to you, then I'd be happy to send a separate PR for a backport.Thanks :)