-
Notifications
You must be signed in to change notification settings - Fork 306
[WIP] feat: use quic multipath #3381
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
base: main
Are you sure you want to change the base?
Conversation
Documentation for this PR has been generated and is available at: https://n0-computer.github.io/iroh/pr/3381/docs/iroh/ Last updated: 2025-08-01T09:29:38Z |
72cb071
to
db712c0
Compare
4827e62
to
946f71c
Compare
iroh-base/src/node_addr.rs
Outdated
)] | ||
pub struct NodeAddr { | ||
/// The node's identifier. | ||
#[debug("{}", node_id.fmt_short())] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this should be reverted before merging
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, do you think so? I found it really annoying to have to look at those full public keys when we debug-log a NodeAddr. I considered using the alternative-debug format, but unfortunately tracing only has ?
and %
support in their macros, for Debug and Display respectively. I didn't thyink there's any strict rule about how a Debug should look? It's not like you can eval()
this back into a thing like e.g. Python.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it reduces the ability to reproduce information, that's why I am concerend about doing it by default. you can copy and paste the nodeid, relayurl and socket addrs currently, but suddenly you can't do it for the nodeid anymore
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A sigil for alternate display in tracing would be the best solution indeed. Looked again and found tokio-rs/tracing#3258 - I now pinged the tokio discord about how to move it forward (pr is open for 6 months without comments)
any_match = true; | ||
match sender.send(*addr, src, transmit).await { | ||
Ok(()) => { | ||
trace!("sent"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
needs delete before merge
any_match = true; | ||
match sender.send(url.clone(), *node_id, transmit).await { | ||
Ok(()) => { | ||
trace!("sent"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
needs delete before merge
warn!(dst = ?destination, "failed to send: {err:#}"); | ||
|
||
let sender = self.msock.node_map.node_state_actor(node_id); | ||
let transmit = OwnedTransmit::from(quinn_transmit); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is very painful, it means we have to allocate each packet that we send one more time 😭
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess this only happens on the mixed path? which seems fine then
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, the tradeoff here is that this only happens for the Intial packet of each connection. Additionally we are not copying the data itself, because that is already a Bytes
instance. So yeah, this was a consious tradeoff made with this design choice.
I guess this design choice isn't documented clearly enough yet.
/// direction as well. | ||
pub needs_ping_back: Option<SendPing>, | ||
} | ||
// TODO: use this |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lots of TODOs in this file
.unwrap_or_else(move || SecretKey::generate(&mut rng)); | ||
|
||
// Override some transport config settings. | ||
self.transport_config |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder if we should check the config and print a warning if we change them, because this does remove the ability for users to configure some of these
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe. Though the upstream API does not allow us to inspect the values :(
This selects paths only from open paths. This avoids paths that haven't been opened yet showing up with 333ms as RTT. To achieve that somewhat reasonably this refactors by moving the path_id_map to be per-connection. The bi-directional map needed becomes a lot simpler to manage, all lookups a lot more sane. And keeping track of open paths becomes easier.
The nice thing is that the setting of PathInfo is now a lot more sane. The bad thing is that we are making random things in the Endpoint and MagicSock pub(crate).
Work on integrating n0-computer/quinn#28 into the iroh magic