forked from apple/servicetalk
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Avoid "Maximum active streams violated for this endpoint"
Motivation: In apple#1307 we changed `LoadBalancedStreamingHttpClient` to not close the connection on cancel for HTTP/2 protocol, because our existing API does not expose methods for closing h2 stream instead of h2 connection. Instead, we had to _prematurely_ mark the request as finished, because in case of cancellation there is no guarantee we will receive a terminal signal on the response. Also, the stream is not aware of `LoadBalancedStreamingHttpConnection` API and therefore it can not mark the request as finished when it closes the stream. That change significantly increased a probability users see "Maximum active streams violated for this endpoint." Even though it's a `RetryableException` it creates pain and still may pop up after auto-retry strategy used all attempts. Modification: - Introduce `OwnedRunnable` that can be passed to the transport layer with the request object; - Add pkg-private `StreamingHttpRequestWithContext` wrapper which delivers `OwnedRunnable` to the transport; - Generate that `OwnedRunnable` in `LoadBalancedStreamingHttpClient`; - `LoadBalancedStreamingHttpClient` marks the request as finished only if it owns `OwnedRunnable`; - If h2-transport takes ownership of the `OwnedRunnable`, `LoadBalancedStreamingHttpClient` is not responsible for marking the request as finished anymore; - Add tests to verify the fix; Result: HTTP/2 requests marked as finished only before they reach transport or only after the stream closes.
- Loading branch information
1 parent
a74c2b4
commit 09cf8c7
Showing
6 changed files
with
757 additions
and
26 deletions.
There are no files selected for viewing
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 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
Oops, something went wrong.