/goben

goben is a golang tool to measure TCP/UDP transport layer throughput between hosts.

Primary LanguageGoMIT LicenseMIT

license Go Report Card

asciicast

goben

goben is a golang tool to measure TCP/UDP transport layer throughput between hosts.

Created by gh-md-toc

Features

  • Support for TCP and UDP.
  • Can limit maximum bandwidth.
  • Written in Go. Single executable file. No runtime dependency.
  • Simple usage: start the server then launch the client pointing to server's address.
  • Spawns multiple concurrent lightweight goroutines to handle multiple parallel traffic streams.
  • Can save test results as PNG chart.
  • Can export test results in YAML format.

History

  • Years ago out of frustration with iperf2 limitations, I wrote the nepim tool. One can find some known iperf problems here: iperf caveats. Nepim was more customizable, easier to use, reported simpler to understand results, was lighter on CPU.
  • Later I found another amazing tool called nuttcp. One can read about nepim and nuttcp here: nepim and nuttcp.
  • goben is intended to fix shortcomings of nepim: (1) Take advantage of multiple CPUs while not wasting processing power. Nepim was single-threaded. (2) Be easily portable to multiple platforms. Nepim was heavily tied to UNIX-like world. (3) Use a simpler synchronous code flow. Nepim used hard-to-follow asynchronous architecture.

Requirements

Install

go get github.com/wcharczuk/go-chart
go get gopkg.in/yaml.v2
go get github.com/udhos/goben
go install github.com/udhos/goben/goben

Usage

Make sure ~/go/bin is in your shell PATH.

Start server:

server$ goben

Start client:

client$ goben -hosts 1.1.1.1 ;# 1.1.1.1 is server's address

Example

Server side:

$ goben
2018/02/08 18:37:28 goben version 0.1 runtime go1.10rc2 GOMAXPROCS=1
2018/02/08 18:37:28 connections=1 defaultPort=:8080 listeners=[":8080"] hosts=[]
2018/02/08 18:37:28 reportInterval=2s totalDuration=10s
2018/02/08 18:37:28 server mode (use -hosts to switch to client mode)
2018/02/08 18:37:28 serve: spawning TCP listener: :8080
2018/02/08 18:37:28 serve: spawning UDP listener: :8080

Client side:

$ goben -hosts localhost
2018/02/08 18:38:48 goben version 0.1 runtime go1.10rc2 GOMAXPROCS=1
2018/02/08 18:38:48 connections=1 defaultPort=:8080 listeners=[":8080"] hosts=["localhost"]
2018/02/08 18:38:48 reportInterval=2s totalDuration=10s
2018/02/08 18:38:48 client mode, tcp protocol
2018/02/08 18:38:48 open: opening tcp 0/1: localhost:8080
2018/02/08 18:38:48 handleConnectionClient: starting 0/1 [::1]:8080
2018/02/08 18:38:48 handleConnectionClient: options sent: {2s 10s 50000 50000 false 0}
2018/02/08 18:38:48 clientReader: starting: 0/1 [::1]:8080
2018/02/08 18:38:48 clientWriter: starting: 0/1 [::1]:8080
2018/02/08 18:38:50 report   clientReader rate:  11565 Mbps  28913 rcv/s
2018/02/08 18:38:50 report   clientWriter rate:  11189 Mbps  27973 snd/s
2018/02/08 18:38:52 report   clientReader rate:  11340 Mbps  28352 rcv/s
2018/02/08 18:38:52 report   clientWriter rate:  10975 Mbps  27438 snd/s
2018/02/08 18:38:54 report   clientReader rate:  11647 Mbps  29117 rcv/s
2018/02/08 18:38:54 report   clientWriter rate:  11272 Mbps  28180 snd/s
2018/02/08 18:38:56 report   clientReader rate:  10957 Mbps  27394 rcv/s
2018/02/08 18:38:56 report   clientWriter rate:  10603 Mbps  26508 snd/s
2018/02/08 18:38:58 workLoop: clientWriter: write tcp [::1]:55186->[::1]:8080: write: connection reset by peer
2018/02/08 18:38:58 average clientWriter rate: 10995 Mbps 27489 snd/s
2018/02/08 18:38:58 clientWriter: exiting: 0/1 [::1]:8080
2018/02/08 18:38:58 report   clientReader rate:  11297 Mbps  28244 rcv/s
2018/02/08 18:38:58 handleConnectionClient: 10s timer
2018/02/08 18:38:58 workLoop: clientReader: read tcp [::1]:55186->[::1]:8080: use of closed network connection
2018/02/08 18:38:58 average clientReader rate: 11361 Mbps 28402 rcv/s
2018/02/08 18:38:58 clientReader: exiting: 0/1 [::1]:8080
2018/02/08 18:38:58 handleConnectionClient: closing: 0/1 [::1]:8080