Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

gh-113538: Allow client connections to be closed #116784

Merged
merged 15 commits into from
Mar 18, 2024

Conversation

CendioOssman
Copy link
Contributor

@CendioOssman CendioOssman commented Mar 14, 2024

This is a new attempt at #114432, with one additional commit to fix unreliably tests.


📚 Documentation preview 📚: https://cpython-previews--116784.org.readthedocs.build/

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.
@CendioOssman
Copy link
Contributor Author

@gvanrossum, this should hopefully be more stable.

Copy link
Member

@gvanrossum gvanrossum left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, this looks like the right solution.

@gvanrossum gvanrossum merged commit 4159644 into python:main Mar 18, 2024
36 checks passed
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.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants