[PR #4780] [client] Fix shutdown blocking on stuck ICE agent close #4402

Open
opened 2025-11-20 08:08:19 -05:00 by saavagebueno · 0 comments
Owner

Original Pull Request: https://github.com/netbirdio/netbird/pull/4780

State: closed
Merged: Yes


Describe your changes

In some cases, the ICE agent will block on Close() indefinitely, blocking the shutdown or restart process.
To avoid that, we add a 3-second timeout after which we abandon waiting for the close operation and proceed with shutdown.

Stack

Checklist

  • Is it a bug fix
  • Is a typo/documentation fix
  • Is a feature enhancement
  • It is a refactor
  • Created tests that fail without the change (if possible)

By submitting this pull request, you confirm that you have read and agree to the terms of the Contributor License Agreement.

Documentation

Select exactly one:

  • I added/updated documentation for this change
  • Documentation is not needed for this change (explain why)

Docs PR URL (required if "docs added" is checked)

Paste the PR link from https://github.com/netbirdio/docs here:

https://github.com/netbirdio/docs/pull/__

Summary by CodeRabbit

  • Bug Fixes
    • Enhanced connection termination robustness with timeout protection for ICE agent shutdown. Prevents the system from hanging indefinitely during network connection cleanup. If shutdown operations exceed timeout limits, the system logs a warning and continues with resource cleanup to ensure proper termination.
**Original Pull Request:** https://github.com/netbirdio/netbird/pull/4780 **State:** closed **Merged:** Yes --- ## Describe your changes In some cases, the ICE agent will block on Close() indefinitely, blocking the shutdown or restart process. To avoid that, we add a 3-second timeout after which we abandon waiting for the close operation and proceed with shutdown. ## Issue ticket number and link ## Stack <!-- branch-stack --> ### Checklist - [x] Is it a bug fix - [ ] Is a typo/documentation fix - [ ] Is a feature enhancement - [ ] It is a refactor - [ ] Created tests that fail without the change (if possible) > By submitting this pull request, you confirm that you have read and agree to the terms of the [Contributor License Agreement](https://github.com/netbirdio/netbird/blob/main/CONTRIBUTOR_LICENSE_AGREEMENT.md). ## Documentation Select exactly one: - [ ] I added/updated documentation for this change - [x] Documentation is **not needed** for this change (explain why) ### Docs PR URL (required if "docs added" is checked) Paste the PR link from https://github.com/netbirdio/docs here: https://github.com/netbirdio/docs/pull/__ <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **Bug Fixes** * Enhanced connection termination robustness with timeout protection for ICE agent shutdown. Prevents the system from hanging indefinitely during network connection cleanup. If shutdown operations exceed timeout limits, the system logs a warning and continues with resource cleanup to ensure proper termination. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
saavagebueno added the pull-request label 2025-11-20 08:08:19 -05:00
Sign in to join this conversation.
1 Participants
Notifications
Due Date
No due date set.
Dependencies

No dependencies set.

Reference: SVI/netbird#4402