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

Make guard to have only one pending reconnect on control connection #462

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

dkropachev
Copy link
Collaborator

@dkropachev dkropachev commented Mar 29, 2025

ControlConnection.reconnect could be calld from many places in parallel. When it happens you get to see streak for reconnects happning one by one.
This commit adds guard that makes sure there is only one pending reconnect.

Old implementation via _ControlReconnectionHandler had following problems:

  1. Did not rewind schedule, effectively stoping reconnection attempts when schedule is exhausted.
  2. Did not provide good API to rewind schedule when it is exhausted.
  3. Did not allow tight control when reconnection stops.
  4. Had convoluted code with no benefits

Pre-review checklist

  • I have split my patch into logically separate commits.
  • All commit messages clearly explain what they change and why.
  • I added relevant tests for new features and bug fixes.
  • All commits compile, pass static checks and pass test.
  • PR description sums up the changes and reasons why they should be introduced.
  • I have provided docstrings for the public items that I want to introduce.
  • I have adjusted the documentation in ./docs/source/.
  • I added appropriate Fixes: annotations to PR description.

@dkropachev dkropachev changed the title Make guard to have only one pending reconnect Make guard to have only one pending reconnect on control connection Mar 29, 2025
@dkropachev dkropachev requested a review from Lorak-mmk March 29, 2025 14:52
@dkropachev dkropachev force-pushed the dk/fix-reconnections-streaks branch 3 times, most recently from cf420ff to 84b6f94 Compare March 30, 2025 13:00
ControlConnection.reconnect could be calld from many places in parallel.
When it happens you get to see streak for reconnects happning one by
one.
This commit adds guard that makes sure there is only one pending
reconnect.
@dkropachev dkropachev force-pushed the dk/fix-reconnections-streaks branch from 84b6f94 to e4d431a Compare March 30, 2025 13:15
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.

1 participant