De-neuter NODE_BLOOM #7708
pull pstratem wants to merge 1 commits into bitcoin:master from pstratem:2016-03-17-nodebloom changing 4 files +2 −5-
pstratem commented at 0:23 am on March 18, 2016: contributorDisconnect nodes which request bloom filtering in violation of the protocol.
-
jonasschnelli added the label P2P on Mar 18, 2016
-
jonasschnelli commented at 7:17 am on March 18, 2016: contributor
See also #6579 for discussions.
utACK.
-
in src/main.cpp: in d2aee0bca6 outdated
4376@@ -4377,7 +4377,7 @@ bool static ProcessMessage(CNode* pfrom, string strCommand, CDataStream& vRecv, 4377 if (pfrom->nVersion >= NO_BLOOM_VERSION) { 4378 Misbehaving(pfrom->GetId(), 100); 4379 return false; 4380- } else if (GetBoolArg("-enforcenodebloom", DEFAULT_ENFORCENODEBLOOM)) { 4381+ } else {
laanwj commented at 9:54 am on March 18, 2016:DEFAULT_ENFORCENODEBLOOM constant in main.h needs to go too :)gmaxwell commented at 10:12 am on March 18, 2016: contributorHas someone checked what impact this would have now? (Wouldn’t preclude a merge in master, since there is still a fair amount of time to respond before release– but it would be good to know).laanwj commented at 10:27 am on March 18, 2016: member@gmaxwell Very little, I expect. the intersection of nodes that::
- Will immediately upgrade to code that includes this
- Set
-peerbloomfilters
false (it defaults to true, and will continue to do so) - Are not yet using
-enforcenodebloom
on 0.12
Is likely to be very, very small.
This is just continuing the planning, in 0.12 NODE_BLOOM was introduced but not yet enforced (by default) for old versions, and the plan is that in 0.13 it will be enforced for all versions.
What kind of measurement do you think should change that planning?
In no case this is going to be backported to 0.12.
jonasschnelli commented at 10:34 am on March 18, 2016: contributorAdded a counter to my SPV stats node to see how many SPV nodes have not adapted the new rule.gmaxwell commented at 10:35 am on March 18, 2016: contributorAh. Indeed, I was forgetting that with peerbloomfilters defaulting to true this would have no effect. Still, interesting to know if there has been any progress or not.pstratem force-pushed on Mar 19, 2016Always disconnect old nodes which request filtered connections. c90036f664laanwj commented at 11:44 am on March 21, 2016: memberACK c90036flaanwj merged this on Mar 21, 2016laanwj closed this on Mar 21, 2016
laanwj referenced this in commit 9426632cb5 on Mar 21, 2016jonasschnelli commented at 6:45 am on August 25, 2016: contributor@rebroad: check https://github.com/bitcoin/bips/blob/master/bip-0111.mediawiki.
Not all nodes want to provide the BLOOM FILTER service. SPV bloom filtering will consume lots of CPU and disk usage. The produced and consumed data will very likely be worthless for the p2p health after generating/transmitting (where a BLOCK or TX structure will be relay further by other full nodes to other full nodes).
BIP-0111 will help SPV clients to detect, which peers do and don’t support the NODE_BLOOM service. Otherwise they need to try and disconnect in case they won’t.
sipa commented at 6:51 am on August 25, 2016: memberAnd not disconnecting them when they request a bloom filter which we don’t provide would make them unnecessarily stall. By disconnecting you give them an opportunity to find a better peer.rebroad commented at 7:02 am on August 25, 2016: contributor@jonasnick @sipa thanks for explanaingcodablock referenced this in commit edd8f6d66f on Sep 16, 2017codablock referenced this in commit 3fe37502ac on Sep 19, 2017codablock referenced this in commit b494eac1bd on Dec 9, 2017codablock referenced this in commit f4d30a6452 on Dec 19, 2017MarcoFalke locked this on Sep 8, 2021
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 03:12 UTC
More mirrored repositories can be found on mirror.b10c.me