[PR #4781] [client] Use stdnet with a context to avoid DNS deadlocks #4403

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

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

State: closed
Merged: Yes


Describe your changes

This change allows us to abort DNS requests even if the OS is stuck on the getaddrinfo syscall by cancelling the context.

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

  • New Features
    • Context-aware network initialization and new public address-resolution APIs for UDP/TCP.
  • Bug Fixes
    • Propagated context and added per-call DNS timeouts to improve cancellation, error handling, and reliability.
  • Tests
    • Updated tests to use the new context-aware network APIs and signatures.
**Original Pull Request:** https://github.com/netbirdio/netbird/pull/4781 **State:** closed **Merged:** Yes --- ## Describe your changes This change allows us to abort DNS requests even if the OS is stuck on the `getaddrinfo` syscall by cancelling the context. ## 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 * **New Features** * Context-aware network initialization and new public address-resolution APIs for UDP/TCP. * **Bug Fixes** * Propagated context and added per-call DNS timeouts to improve cancellation, error handling, and reliability. * **Tests** * Updated tests to use the new context-aware network APIs and signatures. <!-- 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#4403