On Wed, 28 Sep 2022 17:31:46 GMT, Daniel Jeliński <[email protected]> wrote:
>> Please review this patch that makes sure KeepAliveCache does not block all
>> threads while closing sockets.
>>
>> Changes:
>> - get operation no longer closes sockets; if there's no socket that is
>> recent enough, get returns null and lets the cleaner thread close the sockets
>> - put operation closes sockets without holding the cache lock. Additionally,
>> if the cache is full, it places the new connection in the cache and removes
>> the oldest connection.
>> - the cleaner thread creates a list of connections to close, and then closes
>> them after releasing the cache lock
>> - additionally, we set the socket timeout to 1 millisecond before calling
>> socket.close
>>
>> The new test fails with `Wait for second request timed out` without this
>> patch, passes after the changes. Tiers 1-3 clean.
>
> Daniel Jeliński has updated the pull request incrementally with one
> additional commit since the last revision:
>
> Describe oldClient
src/java.base/share/classes/sun/net/www/protocol/https/HttpsClient.java line
442:
> 440: // SSLSocket.close may block up to timeout. Make sure it's
> short.
> 441: serverSocket.setSoTimeout(1);
> 442: } catch (Exception e) {}
Is 1ms enough for a normal SSL close to complete? Does this mean that the
normal close_notify exchange has to complete in that time?
-------------
PR: https://git.openjdk.org/jdk/pull/10401