Skip to content

The iPerf equivalent for the libp2p ecosystem.

License

Notifications You must be signed in to change notification settings

stormshield-pj50/libp2p-perf

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

libp2p-perf

The iPerf equivalent for the libp2p ecosystem.

In a nutshell a client sends as much data as possible through a single multiplexed stream to a server which reads and discards all received data. The client closes the stream after 10 seconds. Subsequently both the client and the server print the result as the total number of bytes transferred and the corresponding bandwidth on stdout.

Implementations

  • Golang

    • Transport: Tcp

    • Transport security: Noise or Plaintext

    • Multiplexing: Yamux

  • Rust

    • Transport: Tcp

    • Transport security: Noise or Plaintext

    • Multiplexing: Yamux

Getting started

$ make


$ ./run.sh
# Start Rust and Golang servers.

# Rust -> Rust

## Transport security noise
Interval        Transfer        Bandwidth
0 s - 10.00 s   7713 MBytes     6169.19 MBit/s

## Transport security plaintext
Interval        Transfer        Bandwidth
0 s - 10.00 s   11703 MBytes    9362.40 MBit/s

# Rust -> Golang

## Transport security noise
Interval        Transfer        Bandwidth
0 s - 10.00 s   7603 MBytes     6080.17 MBit/s

## Transport security plaintext
Interval        Transfer        Bandwidth
0 s - 10.00 s   22171 MBytes    17736.72 MBit/s

# Golang -> Rust

## Transport security noise
Interval        Transfer        Bandwidth
0s - 10.01 s    7919 MBytes     6331.07 MBit/s

## Transport security plaintext
Interval        Transfer        Bandwidth
0s - 10.01 s    20871 MBytes    16682.93 MBit/s

# Golang -> Golang

## Transport security noise
Interval        Transfer        Bandwidth
0s - 10.00 s    8051 MBytes     6438.80 MBit/s

## Transport security plaintext
Interval        Transfer        Bandwidth
0s - 10.00 s    25222 MBytes    20177.50 MBit/s

$ cat /proc/cpuinfo | grep "model name" | head -1
model name      : Intel(R) Core(TM) i7-8550U CPU @ 1.80GHz

License

Licensed under either of

at your option.

About

The iPerf equivalent for the libp2p ecosystem.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 81.6%
  • Go 10.9%
  • Shell 5.6%
  • Makefile 1.9%