-
Notifications
You must be signed in to change notification settings - Fork 2.8k
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
feat: add pending connection limits + bump libp2p to 0.54.1
#2150
base: master
Are you sure you want to change the base?
Conversation
bin/fuel-core/src/cli/run/p2p.rs
Outdated
|
||
/// Max number of concurrent pending outgoing connections | ||
#[clap(long = "max-pending-outgoing-connections", default_value = "100", env)] | ||
pub max_pending_outgoing_connections: u32, |
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.
Even though I've added this parameter, I'm not fully sold that it should be present. The rationale is we only dial a peer if:
a) We are below the desired amount of peers in a gossipsub mesh (which would imply we would be below any potential max_pending_outgoing_connections
anyway) and we determined that the peer in question would have a reasonable peer score. So essentially our gossipsub config should handle this scenario.
AND
b) We are relatively certain that peer is reachable i.e. the multiaddr
for that peer can be successfully dialled - if that is so, we want to prioritize dialling it.
But I may be missing something about the current p2p setup.
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.
You are unsure if we should put a limit on outgoing connections?
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.
Correct, more specifically on outgoing pending connections (as opposed to established outgoing connections)
0.54.1
0.54.1
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.
For me that's an interesting add but it's doesn't close : #1560. IMO, in order to close this issue we also need to add parameters for the number of established connections (in/out)
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.
Looks good to me. Little nit on the CHANGELOG. Can you update it now that you have a new parameter added ?
Good catch @AurelienFT , I've updated it in 1127c72 |
We shouldn't merge this PR before #2131 Plus, let's wait for my review as well, since maybe we need to clean up some other logic |
How's this coming? |
Thanks for resurfacing this @MitchTurner it got lost in the ether with the mainnet whirlwind of changes. I've resolved the conflicts so it's ready for review again. I know @xgreenx wanted to look into it again but the changes imo are relatively low surface - I've upgraded our libp2p version + introduced connection limit options. |
Hello @maschad, As you mentionned that @xgreenx wanted to look again we will wait him before merging this but I can already re-approve as a first approver. However before approving the conflicts should be resolved, are you ok to resolve them ? Or we can do it for you, if you prefer :) Thanks again for this PR. |
Thanks @AurelienFT I've gone ahead and resolved the conflicts. |
@maschad is it okay if I take over this PR? there seem to be some formatting issues |
b07713b
to
1f9291f
Compare
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.
LGTM. Ty @rymnc for takeover
Linked Issues/PRs
connection_limits
behavior toFuelBehavior
#1560Description
This is apart of the broader initiative outlined in #1968 to improve the DoS resilience
This PR doesn't make the pending connection limits configurable for a reason, it is an easy way for the operator to footgun and mess up the node configuration. We've used some defaults for now, but there should be some analysis done on optimal connection count for latency to propagate messages.
Checklist
Before requesting review