◐ Shell
clean mode source ↗

gh-113538: Allow client connections to be closed by CendioOssman · Pull Request #116784 · python/cpython

added 15 commits

January 22, 2024 11:30
Give applications the option of more forcefully terminating client
connections for asyncio servers. Useful when terminating a service and
there is limited time to wait for clients to finish up their work.
We want to be able to detect if the application fails to keep track of
the transports, so we cannot keep them alive by using a hard reference.
The application might be waiting for all transports to close, so we need
to properly inform the server that this transport is done.
One could be made clearar, and the other is probably superfluous.
Try to get the streams and the kernel in to a more deterministic state
by specifying fixed buffering limits.
No possibly infinite loop. Instead ask the system how much buffer space
it has and fill that.
In case it takes some time, as we need access to the server side
stream objects to perform the test.

gvanrossum

vstinner pushed a commit to vstinner/cpython that referenced this pull request

Mar 20, 2024
…on#116784)

These give applications the option of more forcefully terminating client
connections for asyncio servers. Useful when terminating a service and
there is limited time to wait for clients to finish up their work.

This is a do-over with a test fix for pythongh-114432, which was reverted.

adorilson pushed a commit to adorilson/cpython that referenced this pull request

Mar 25, 2024
…on#116784)

These give applications the option of more forcefully terminating client
connections for asyncio servers. Useful when terminating a service and
there is limited time to wait for clients to finish up their work.

This is a do-over with a test fix for pythongh-114432, which was reverted.

diegorusso pushed a commit to diegorusso/cpython that referenced this pull request

Apr 17, 2024
…on#116784)

These give applications the option of more forcefully terminating client
connections for asyncio servers. Useful when terminating a service and
there is limited time to wait for clients to finish up their work.

This is a do-over with a test fix for pythongh-114432, which was reverted.