-
Notifications
You must be signed in to change notification settings - Fork 1k
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
[Discussion] Mplex future #3490
Comments
Yep, I think the plan is to deprecate mplex once all the client teams have full support and prioritize it. Hopefully we can get this done before the next hard fork. |
Other clients can chime in, but I think we might only get yamux fully supported and tested after deneb across all clients. So we will have to maintain mplex for a while. For that reason |
+1 for the hf after deneb. Practically, I envision clients will first support yamux then prefer it then mplex will finally be removed, resulting in a gradual migration. |
@jxs nit but an important one, any chance you can change s/"Protocol Labs"/"different implementations like go, rust, and js-libp2p are" as PL =/= the different implementations |
this is a libp2p spec deprecation first and foremost and PL maintains the spec - implementations follow, but they are not driving the deprecation in this case |
Thanks for the suggestion Prithvi, updated it |
Besides requiring stable yamux support in all implementation, the underlying libp2ps require a clever mechanism (which is not part of the specs) to have the same performance as mplex with more than 256kb in flight on a specific stream. Using yamux without this mechanism would cause an extra ~500ms delay on block propagation when they are >256kb, which we can expect from deneb As long as this is not resolved, we shouldn't switch, imo |
And FWIW I agree with @arnetheduck, how can you say that the push to switch to yamux is coming from the libp2p implementations, when more than half of them don't have even a stable yamux yet @p-shahi? While I appreciate the fact that thanks to the deprecation, things are starting to move towards yamux, this is very done very hastily, without consideration for networks with multiple libp2ps, and a big step back in term of libp2p interoperability. (sorry for the off-topic) |
Mplex is currently the main multiplexing protocol supported by all Ethereum consensus clients, while yamux
MAY
be supported:consensus-specs/specs/phase0/p2p-interface.md
Lines 164 to 167 in e3a939e
Libp2p is deprecating Mplex on libp2p ¹ and making yamux the main and the only multiplexer for TCP.
Lighthouse
already supports yamuxPrysm
already supports it and has recently made it the first choice for multiplexingNimbus
has recently added yamux supportLodestar
has a PR open with yamux supportTeku
has a PR open with yamux supportWith that in mind, should we update the spec to swap
Mplex
toMAY
support and yamux toMUST
support?The text was updated successfully, but these errors were encountered: