-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Decrease default --out-peers from 25 to 15 #12434
Conversation
DQ: Do we randomly kick peers over time to make room for new peers? If not, should we not do this? And instead of changing the number, should we not just change our Polky net to have the nodes running with some better CLI settings? |
No we don't, yeah it's been on the networking TODO list for ages.
I don't understand what you want to do? |
I mean you are changing the default values of the CLI here. Which probably works for Polky, but if we start scaling Polky, we could still run into the "network is full crisis" or not? So, I would say that we should run the nodes with a set of CLI parameters that represent the expected number of nodes in the test network. |
Ah yeah, the objective of this PR is to modify the values that the network as a whole uses, not to modify just Polky. |
As a data point, if I run the smoldot full node, it can't find anyone to connect to, but I change the code of the full node to pretend that it's a light client, then it finds tons of peers and syncs very smoothly. This is the case because we have extra in slots for light clients. It confirms, to me, that we just need to increase the number of unoccupied slots on the network as a whole. |
DQ but why do you decrease |
Increasing in-peers or decreasing out-peers is the same, but I went for decreasing because 50 peers is already way too many and as far as I know we encounter performance/bandwidth issues due to the high networking load. |
Ping. What's wrong with this PR? |
Could we at least in the CLI docs add some comment of |
But that's not really true. It is better for the network as a whole if the number of inbound peers is greater than the number of outbound peers, but it's not a requirement. People who customize these numbers normally do so because they know what they're doing, and we don't really care about what individual people who know what they are doing are actually doing. The objective is just to change the default values so that people who don't know what they are doing are beneficial to the network by default. |
bot merge |
Waiting for commit status. |
Merge cancelled due to error. Error: Statuses failed for 21c947a |
Co-authored-by: Bastian Köcher <[email protected]>
I've spent the morning trying to understand why smoldot can't easily connect to the peer-to-peer networks.
After some analysis, my conclusion is that we have a "everyone is full" crisis.
Because everyone uses the same value for
--out-peers
and--in-peers
, every long-running node is tightly connected and doesn't accept any new connection.The discovery process is biased towards old nodes (that's how Kademlia works), thus new nodes are most likely to find full nodes.
But let's say you start a new Polkadot instance from scratch. We'll name it Polky. Why does Polky have no problem finding peers, then? Well, it's the combination of two things:
Anyway, the reality is that every node on the network seems to be full.
In order to improve that situation, this PR decreases from 25 to 15 the default value for
--out-peers
.