Welcome to the Metronome repository for CoNEXT 2020 artifacts evaluation.
We provide the necessary code and documentation to test Metronome on your commodity servers and replicate our experiments.
The repository is organized with two main directories:
- hr_sleep: contains the kernel module to load the hr_sleep patch and a basic test to verify its correct working and the performance gain compared to Linux' nanosleep().
- tests: contains the tests explained in Section 5.5 of the paper. We encourage reviewers to use the l3fwd experiment as it is the one used for evaluation in Section 5.
The hr_sleep module was tested on Linux kernel 5.4, and older kernel version are expected to work too. Please note that this is currently not working for Linux kernel 5.7 or newer.
This guide is intended for Intel x86 CPUs only.
Our tests have been executed with Metronome running on isolated CPUs. Although this step is not strictly necessary, we recommend it in order to obtain results which are more reproducible and also closer to the evaluation. This video shows how to isolate CPUs in Ubuntu. If you wish to isolate your CPUs, please execute this step first since it will imply a machine reboot.
We used the DPDK 19.11.1 LTS stable release which can be downloaded here. Different releases of the DPDK 19.11 LTS release should work as well.
Once downloaded, uncompress the archive and move to the uncompressed DPDK directory:
$ tar xJf dpdk-19.11.1.tar.xz
$ cd dpdk-19.11.1
Before compiling DPDK install the required dependencies (for Ubuntu/Debian systems, for other systems please refer to the official guide here):
$ sudo apt-get update
$ sudo apt-get install git build-essential linux-headers-`uname -r`
Now compile with:
$ make config T=x86_64-default-linuxapp-gcc
$ make
$ make install
After DPDK is successfully compiled, please insert the igb_uio driver doing
$ sudo modprobe uio
Then from your root DPDK directory do:
$ sudo insmod build/kmod/igb_uio.ko
We used Moongen to generate high traffic of packets.
Clone the Moongen repository with:
$ git clone https://github.com/emmericp/MoonGen.git
Then install the required dependencies:
$ sudo apt-get install -y build-essential cmake linux-headers-`uname -r` pciutils libnuma-dev
Finally build Moongen with:
$ cd MoonGen
$ ./build.sh
Please note that the setup done by MoonGen may cause loss of connectivity, as MoonGen tries to bind to the DPDK driver all of the inactive interfaces.
Using Moongen allows you also to reproduce the experiments used by the software-switches repo for evaluation.
For our tests, we used commit 525d991
of the master
branch.
You can clone the software-switches repo here. For our purposes, only the moongen/
directory is needed. There's no need to compile or setup anything.
We used commit 5af2439
of the artifacts
branch.
Switch to the hr_sleep directory and follow the instructions in the directory's README file.
Please make sure that all of the interfaces you wish to use are bound to the DPDK driver. To see the status of all ports of your network system, run:
$ cd YOUR_DPDK_HOME
$ ./usertools/dpdk-devbind.py --status
Network devices using DPDK-compatible driver
============================================
0000:82:00.0 '82599EB 10-GbE NIC' drv=igb_uio unused=ixgbe
0000:82:00.1 '82599EB 10-GbE NIC' drv=igb_uio unused=ixgbe
Network devices using kernel driver
===================================
0000:04:00.0 'I350 1-GbE NIC' if=em0 drv=igb unused=igb_uio *Active*
0000:04:00.1 'I350 1-GbE NIC' if=eth1 drv=igb unused=igb_uio
0000:04:00.2 'I350 1-GbE NIC' if=eth2 drv=igb unused=igb_uio
0000:04:00.3 'I350 1-GbE NIC' if=eth3 drv=igb unused=igb_uio
Other network devices
=====================
<none>
To bind interface eth1
(with PCI address 04:00.1
) to the igb_uio
driver:
$ ./usertools/dpdk-devbind.py --unbind 04:00.1
$ ./usertools/dpdk-devbind.py --bind=igb_uio 04:00.1
We used the experiments inside the software-switches/moongen
repo, in particular unidirectional-test.sh
for throughput tests and latency-test.sh
for latency measurements.
These test must be started only after the Metronome l3fwd
example is running. Please refer to the README in the tests/l3fwd
directory in order to make Metronome run correctly.
Before starting them, please modify these .sh files in order to specify in the MOONGEN_DIR
parameter your Moongen installation path. Please also modify your dpdk-conf.lua
script in order to specify the cores where to run Moongen, the interfaces to be used and the memory allocation.
N.B. please specify your interfaces in the same order you see them through the ./usertools/dpdk-devbind.py --status
command (that is, ascending order). The first interface you specify will likely be used for sending, and the second one for receiving.
You can switch now to the examples/l3fwd
directory to test our main example.