[Alpha] High Speed Latency-Meter using DPDK
This application allows to measure the network's Latency and Bandwith. Current phase: Early development
Clonning
To clone this project execute:
git clone git@github.com:hpcn-uam/iDPDK-LatencyMeter.git
git submodule update --init --recursive
if you want to update (pull) to a newer commit, you should execute:
git pull
git submodule update --init --recursive
DPDK-Compilation
The latest tested DPDK-repository with this application is included in the dpdk
folder.
Howerver, any other compatible-version could be used by exporting RTE_SDK
variable.
To compile the included DPDK-release, it is recomended to execute and follow the basic dpdk-setup.sh
script, example:
cd dpdk
./tools/dpdk-setup.sh
cd ..
APP-Compilation
The application is compiled automatically when executing one of the provided scripts.
If you prefere to compile it manually, in the src
folder there is a Makefile
to do it.
Execution
In script
folder, there are some example scripts:
scripts/interface0.sh
starts measuring the latency in the interface number 0. Using it to send and receive packets.scripts/interface0.40g.sh
It is a similar script than the adove. This script uses 2 tx queues to saturate efficiently a 40G Ethernet link.scripts/interface01.sh
starts measuring the latency in the interface number 0 and 1. Using interface 0 to send and interface 1 to receive packets.
The typical test, can be sumarized with the following execution parameters:
- Measure latency and bandwidth using packet trains:
./scripts/interface01.sh --trainLen 1000 --pktLen 60 --sts
- Measure only bandwidth (it will saturate the link non-stop):
./scripts/interface01.sh --bw --pktLen 60
- Measure only latency (a sleep should be produced between packets):
./scripts/interface01.sh --trainLen 1000 --pktLen 1500 --trainSleep 2000
Also, those scripts accept the following extra (optional) parameters:
--etho "aa:bb:cc:dd:ee:ff" : The ethernet origin MAC addr
--ethd "aa:bb:cc:dd:ee:ff" : The ethernet destination MAC addr
--ipo "11.22.33.44" : The ip origin addr
--ipd "11.22.33.44" : The ip destination addr
--pktLen "Packet LENGTH" : Sets the size of each sent packet
--trainLen "TRAIN LENGTH" : Enables and sets the packet train length
--trainSleep "TRAIN SLEEP": Sleep in NS between packets
--sts : Mode that sends lots of packets but only a few are timestamped
--waitTime "WAIT TIMEOUT" : Nanoseconds to stop the measurment when all
packets has been sent
--chksum : Each packet recalculate the IP/ICMP checksum
--autoInc : Each packet autoincrements the ICMP's sequence number
--bw : Only measures bandwidth, but with higher resolution
--bwp: Only measures bandwidth(pasive) by just listening. No packet is sent
--lo : The application works in loopback mode. Used to measure RTT
Calibration
We are developing a auto-config/calibration to the system. In order to test the calibration, you can try the following parameters:
--calibrate \"outputFile\" : Generate a calibration file. May take hours
--calibration \"inputFile\" : Open a calibration file, to fix measurements