1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/dist/tools/benchmark_udp/README.md
2021-09-02 23:12:31 +02:00

52 lines
1.9 KiB
Markdown

# UDP Benchmark server
This is a simple tool to generate load and evaluate the performance and reliability of a network.
Clients will periodically send UDP packets to the benchmark server, the server keeps track of
how many packets have been received and how many the nodes have reported to send.
By default the server will also echo the packets back to the sender so round-trip time can be
measured.
### Usage
### Server
Run the binary you find in `bin/benchmark_server`.
e.g. to listen on all addresses on port 12345 run
bin/benchmark_server :: 12345
There are a few command line options available:
- `-i <interval>` to control the send interval in µs
- `-s <size>` to control the test packet payload
- `-o` for one-way mode where only the clients send packets to the server, but the server doesn't echo them back.
Output:
- 'host': client address
- 'bandwidth': average bandwidth since the last configuration package
- 'num TX': number of packaged produced by the client since the configuration package
- 'num RX': number of packaged received by the server since the configuration package
- 'num RT': number of server echos received by the client since the last configuration package
- 'RTT': round trip time client->server->client (last package received by client)
### Client
On the application that you want to benchmark, add the `benchmark_udp` module.
If you have the shell enabled you can then start the benchmark manually by
bench_udp start <address> <port>
If port is omitted it will default to `12345` (`BENCH_PORT_DEFAULT`), if the address is omitted `fd00:dead:beef::1` (`BENCH_SERVER_DEFAULT`) will be used.
If the benchmark should be started automatically, add the `auto_init_benchmark_udp` module.
In this case, `BENCH_SERVER_DEFAULT` and `BENCH_PORT_DEFAULT` will be used.
They can be overwritten via CFLAGS:
CFLAGS += -DBENCH_SERVER_DEFAULT=\"<addr>\"
CFLAGS += -DBENCH_PORT_DEFAULT=<port>