-
-
Notifications
You must be signed in to change notification settings - Fork 35
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
throughput is 5 MB/s on loopback #3
Comments
There are some justifications in the README. Working over localhost on my MBP, using the provided pingpong utility (which I'll update in a sec), I get the following performance: utp->libutp 20.7MiB/s For a 348MiB file. I think there's some improvements that can be made to receiving, it seems to take a few seconds to accept. Also utp->utp isn't great. In the wild, utp usually interacts with libutp or some other derivative, so performance isn't necessarily the worst case. If you'd like to help out, the low hanging fruit is doing some profiling, and fiddling with the MTU value in the library. |
There was some congestion in Socket.dispatcher, which I've rewritten. It seems to have improved speeds a bit. Where other_ucat is libutp's ucat, and before changes on the left, and after on the right: utp->other_ucat |
With some ricing of constants it's now For utp->utp that's nearly 4x the speed I got with the revision this issue was reported. |
👍 nice progress!. i've formatted the table better:
curious that |
Thanks for that. I expect it has to do with only selectively acking the next 64 inbound packets, or something I'm feeding libutp in my outbound headers that it doesn't like. Interestingly, lib->go is actually the most important metric for the torrent use case as it represents inbound throughput, though it's a non-issue as that's ~18-19MiB per peer. If you have any feedback from your project @jbenet , that would be great. |
@anacrolix we haven't deployed it cause we were waiting for this throughput fix. I think 19MiB per peer is good enough to try. we'll ship it and report back results. if you'd like to have any metrics, we can see about adding them. go-ipfs can output both custom event logs and prometheus logs. |
Also, @anacrolix i've been meaning to setup some benchmarks to check out throughput of various transports (uTP, UDT, SCTP, QUIC, ...) on various kinds of network setups. would be interesting to have a great bandwidth benchmark for transports using real networks to test them. if you're interested in this, we will be adapting golang/build to help us run these. |
Improves libutp->utp performance from ~18.8MiB/s to ~25MiB/s. See issue #3.
Performance now:
Localhost doesn't take into account connections between peers with greater latencies, so I'm closing this issue on account of the localhost performance is already greatly improved, and further ricing is at the detriment of more important real world scenarios. Thanks. |
👏 👏 👏 great work @anacrolix ! we're deploying this un go-ipfs |
Hey, One question. Has this seen any production use? Thanks. |
@anacrolix did you get only ~30 MB/s with ucat->ucat over loopback? I get almost 90 MB/s ... |
@anacrolix Thanks for the great work so far! I've started the integration of utp into ipfs here: ipfs/kubo#1789 It works moderately well. although we've seen a few random halts which arent necessarily caused by utp, theres a chance it is. I can continue to post updates here or elsewhere if you'd like, and I'll be sure to file issues for anything I find. |
@AudriusButkevicius : The packet is used in production 24/7 by an application using package torrent. @whyrusleeping : If you get any more information about the stalls with package utp, please report an issue. |
Hi
I tested with go 1.5 on Mac Air:
This is compared to native build of ucat from https://github.com/bittorrent/libutp:
That's a big drop..
Cheers
The text was updated successfully, but these errors were encountered: