Hash P2P messages as they are received instead of at process-time #9045
pull TheBlueMatt wants to merge 1 commits into bitcoin:master from TheBlueMatt:2016-10-p2p-hash changing 3 files +15 −1-
TheBlueMatt commented at 10:09 pm on October 30, 2016: memberBetter to hash as you receive bytes from the wire so that you reduce latency when you have the full message, arguably. If anything else probably best to not do the hashing in the message processing thread.
-
Hash P2P messages as they are received instead of at process-time fe1dc62cef
-
sipa commented at 10:28 pm on October 30, 2016: memberutACK. Somehow I thought we were already doing this.
-
fanquake added the label P2P on Oct 31, 2016
-
gmaxwell commented at 6:30 am on October 31, 2016: contributorACK
-
rebroad commented at 8:50 am on October 31, 2016: contributor@TheBlueMatt Did you time how long the hashing was taking on a typical full block?
-
paveljanik commented at 12:16 pm on October 31, 2016: contributor@rebroad This is about P2P messages and their checksums…
-
paveljanik commented at 12:16 pm on October 31, 2016: contributor
-
TheBlueMatt commented at 12:33 pm on October 31, 2016: member
I did not Rome the hashing, though I expect it to be between 3 and 10 ms (we use a particularly slow SHA256 implementation, as we don’t incorporate any handcoded asm), but the lower bound is about 3, assuming it’s cache-hot.
On October 31, 2016 4:50:20 AM EDT, R E Broadley notifications@github.com wrote:
@TheBlueMatt Did you time how long the hashing was taking on a typical full block?
You are receiving this because you were mentioned. Reply to this email directly or view it on GitHub: #9045 (comment)
-
theuni commented at 8:48 pm on October 31, 2016: member
mm, NACK unless there are numbers that show that this is preferable.
- This removes our ability to selectively hash. If we’re flooded with thousands of messages that we would otherwise drop after the first, we still end up hashing them.
- Removes the ability to skip hashing for known values. For example, hashing for “sendheaders” could be skipped and we could just check against the known-correct value.
- The socket polling loop needs to be as tight as possible.
- Message processing could definitely be done multi-threaded, but multi-threaded polling is unlikely.
-
TheBlueMatt commented at 10:46 pm on October 31, 2016: member
@theuni While hashing is incredibly fast, it can be cause a big hit to latency for time-from-block-receive-to-relay (lower bound on hashing 1MB is around 3ms, whereas total runtime for deserialize and AcceptBlock, not including storage, is something like 15ms), especially if you received the full “block” message. Doing it as packets come in off the wire should never be a bottleneck - hashing is, more often than not, going to be able to easily keep up with your wire speed. This means that you can hash the message as it comes off the wire and when you receive the last packet (ie are ready to start processing) you dont have to wait for hashing to complete.
Indeed, it complicates CConnman somewhat but CNetMessage will likely have to change for protocol encryption anyway, so its not like the logic in the same place isnt gonna have to learn protocol encryption.
-
theuni commented at 7:07 pm on November 7, 2016: member@TheBlueMatt ok, I’ve come around on this. Thanks to @gmaxwell and @sipa for the discussion over the weekend. utACK https://github.com/bitcoin/bitcoin/pull/9045/commits/fe1dc62cef88280d2490a619beded052f313c6fc.
-
sipa merged this on Nov 7, 2016
-
sipa closed this on Nov 7, 2016
-
sipa referenced this in commit 9f554e03eb on Nov 7, 2016
-
codablock referenced this in commit 9b8cc0b1ce on Jan 15, 2018
-
andvgal referenced this in commit 13874fc795 on Jan 6, 2019
-
CryptoCentric referenced this in commit 5b6a3dac57 on Feb 24, 2019
-
barrystyle referenced this in commit ae602cc60f on Jul 6, 2019
-
random-zebra referenced this in commit bffe509aed on Jun 28, 2021
-
DrahtBot locked this on Sep 8, 2021
TheBlueMatt
sipa
gmaxwell
rebroad
paveljanik
theuni
Labels
P2P
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-07 06:12 UTC
More mirrored repositories can be found on mirror.b10c.me