-
Notifications
You must be signed in to change notification settings - Fork 280
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
[GossipSub 1.2] Allow sending IDONTWANTs when publishing #642
base: master
Are you sure you want to change the base?
Conversation
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.
That sounds reasonable, whats the implementation status?
Hi Vyzo, on our case it's implemented and merged soon to be released, on other implementations I don't know. |
ok, lets wait a little for the other implementations to catch up and we merge it |
Implemented in JVM-libp2p here: libp2p/jvm-libp2p#386 |
@ppopth can confirm, but we should already be doing this in the go-implementation when publishing |
No, go-libp2p-pubsub is not doing this now. It has to be implemented. |
@@ -56,6 +56,7 @@ This section lists the configuration parameters that needs to agreed on across c | |||
When the peer receives the first message instance it immediately broadcasts | |||
(not queue for later piggybacking) `IDONTWANT` with the `messageId` to all its mesh peers. | |||
This could be performed prior to the message validation to further increase the effectiveness of the approach. | |||
Additionally, on networks where multiple messages share the same messageId, a user may choose to broadcast IDONTWANT when publishing. |
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 think it's good to note that the publisher still shouldn't publish the message to the peers that previously sent an IDONTWANT to the publisher.
It's trivial to know this but I'm afraid that some implementers will forget this.
This PR introduces an optimisation to preemptively broadcast `IDONTWANT` for published messages, preventing redundant downloads of the same message received over gossip. This feature is opt-in and respects the existing `idontwant_message_size_threshold`. By default, `IDONTWANT` messages will only be sent for published messages larger than 1000 bytes. reference PRs: [spec](libp2p/specs#642) Pull-Request: #5773.
With the introduction of
getBlobsV1
for the Cancun upgrade in the Ethereum network, nodes may publish blobs (messages) retrieved from the Execution Layer without receiving them through Gossipsub. In such cases, a node already has the blobs and can conserve download bandwidth by sending out IDONTWANT messages to peers for the blobs it publishes. This prevents the node from receiving the same blobs again through gossip.This PR aims to clarify the behavior at the specification level.
See more here
Thanks!