RFR: 8343855: HTTP/2 ConnectionWindowUpdateSender may miss some unprocessed DataFrames from closed streams [v2]

Andrey Turbanov aturbanov at openjdk.org
Tue Nov 12 19:28:21 UTC 2024


On Mon, 11 Nov 2024 16:52:53 GMT, Daniel Fuchs <dfuchs at openjdk.org> wrote:

>> [JDK-8342075](https://bugs.openjdk.org/browse/JDK-8342075) has introduced more flow controls checks, but also introduced a race condition where DataFrames for closed streams may fail to be discounted from the connection window.
>> 
>> The consequence is that WINDOW_UPDATE frames for the connection window may not be sent when they should, preventing the server from making progress and stalling the connection.
>> 
>> This can be shown by modifying the StreamFlowControlTest to send less but bigger frames (e.g. chunks of 1600 bytes instead of chunks of 12 bytes). With such a modification the test can be seen failing intermittently, when sameClient=true.
>> 
>> The race happens when frames that have been added to Stream::inputQ fail to be drained after the stream is closed (or continue to be added to the inputQ after the stream is closed).
>> 
>> The fix ensures that Stream::drainInputQueue() is called when the stream is closed, and that no further data farme will be added to the inputQ after the stream is marked closed.
>> 
>> The modified StreamFlowControlTest could be observed failing relatively frequently on linux-aarch64 without the fix.
>> With the fix the test no longer fails.
>
> Daniel Fuchs has updated the pull request incrementally with one additional commit since the last revision:
> 
>   Add more comments

test/jdk/java/net/httpclient/http2/StreamFlowControlTest.java line 285:

> 283: 
> 284:         // warmup to eliminate delay due to SSL class loading and initialization.
> 285:         try (var client = HttpClient.newBuilder().sslContext(sslContext).build();) {

Suggestion:

        try (var client = HttpClient.newBuilder().sslContext(sslContext).build()) {

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/21991#discussion_r1838646986


More information about the net-dev mailing list