Control rate of HTTP/1 writes #180
Merged
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 NOT A MERGE TO MASTER. CI WILL FAIL. WORKS ON MY MACHINE THOUGH.
HTTP/1 was writing one 16KB message per event-loop tick, regardless of whether that data was making it to the network. This wastes memory on a slow network, and made it hard for us to measure the actual write throughput.
This PR makes it so HTTP/1 waits until a message makes it to the network before attempting to write another.
Also removed hacks that had the stream complete when a 101 Switching Protocols response came in. 1xx responses should never complete the stream. Websockets needed to adapt to this change and install its handler the moment the response came in, instead of waiting for the stream to end.
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.