This repository contains the evaluation scripts used to measure Queue-Mem performance.
This repository contains:
- generator: FAJITA elements and scripts used to generate traffic towards a Tofino switch;
- trex: scripts and PCAP traces used from the TRex experiments;
- bq_mcast: different P4 programs to either (i) multicast incoming traffic towards the Queue-Mem switch or (ii) generate and multicast traffic towards the Queue-Mem switch;
- scripts: evaluation scripts and results plotter.
Most of the experiments require two Tofino switches (a Tofino2 for Queue-Mem and a Tofino1 for the multicaster), an external server that acts as a traffic generator, and two NF servers. Some experiments (iperf and TRex) require additional servers acting as client/server.
The traffic generator uses FAJITA.
We used Ubuntu 20.04.4 LTS as the Operating System on the server.
First compile and install DPDK, following this tutorial. We used DPDK 21.08.0, and it is the only tested version.
After installing DPDK, pull both this repository and FAJITA:
$ git clone https://github.com/Queue-Mem/queue-mem-experiments.git
$ git clone https://github.com/FAJITA-Packet-Processing-Framework/FAJITAIn our testbed, FAJITA has been configured with the following command:
$ cd FAJITA
$ PKG_CONFIG_PATH=/path/to/dpdk/install/lib/x86_64-linux-gnu/pkgconfig ./configure --enable-dpdk --enable-intel-cpu --verbose --enable-select=poll "CFLAGS=-O3" "CXXFLAGS=-std=c++17 -O3" --disable-dynamic-linking --enable-poll --enable-bound-port-transfer --enable-local --enable-flow --disable-task-stats --enable-cpu-load --enable-dpdk-packet --disable-clone --disable-dpdk-softqueue --enable-research --disable-sloppy --enable-user-timestampReplace the PKG_CONFIG_PATH with the path of your DPDK installation.
Build the project:
$ makeTo install TRex, follow the official guide.
You need a Tofino to build and run the bq_mcast, bq_forwarder, and bq_ecmp programs. This Tofino switch should be connected with some ports to the Queue-Mem Tofino. The default configuration uses 14 ports.
To build the code, use the following command:
./p4_build.sh /path/to/bq_mcast.p4
# or
./p4_build.sh /path/to/bq_forwarder.p4
# or
./p4_build.sh /path/to/bq_ecmp.p4The programs have been tested on SDE 9.8.0.
In this folder, you will find both the bash scripts to run the paper experiments and a plot.py to plot all the figures of the paper.
The plot.py requires matplotlib:
python3 -m pip install matplotlibTo change the ports in the bq_mcast program, you need to:
- Change the port_to_idxtable in bothbq_mcast.p4andbq_forwarder.p4:
@ternary(1)
table port_to_idx {
    key = {
        eg_intr_md.egress_port: exact;
    }
    actions = {
        assign_idx;
    }
    size = N_MULTICAST;
    const entries = {
        60: assign_idx(0);
        44: assign_idx(1);
        36: assign_idx(2);
        28: assign_idx(3);
        20: assign_idx(4);
        12: assign_idx(5);
        4: assign_idx(6);
        128: assign_idx(7);
        136: assign_idx(8);
        144: assign_idx(9);
        152: assign_idx(10);
        176: assign_idx(11);
        184: assign_idx(12);
        148: assign_idx(13);
    }
}- Change the setup*.pyfiles, for example, the one ofsetup_bq_forwarder.py:
PORTS = [
    52, 32, 140, # Traffic Gen + NF Ports
    60, 44, 36, 28, 20, 12, 4,
    128, 136, 144, 152, 176, 184, 148
]You then need to recompile the P4 program.
You need to define some variables in the bash scripts to run the tests.
Copy the set_env.bash.template and rename it set_env.bash. In the file, you will find the following variables:
- TOFINO_USERNAME: the Linux user on both Tofinos;
- TOFINO_USER_PASS: the user password on both Tofinos;
- QUEUEMEM_TOFINO_NAME: the name/IP of the Tofino where Queue-Mem is installed;
- MCAST_TOFINO_NAME: the name/IP of the Tofino where- bq_mcastis installed;
- NF_SERVER_USERNAME: the Linux user on the server used as NF;
- NF_SERVER_USER_PASS: the user password on the server used as NF;
- NF_SERVER_NAME_1: the name/IP of the first server used as NF;
- NF_SERVER_NAME_2: the name/IP of the second server used as NF;
- IPERF_SERVER_NAME_1: the name/IP of the server used as iPerf Server;
- IPERF_CLIENT_NAME_1: the name/IP of the server used as iPerf Client;
- GENERATOR_SERVER_USERNAME: the Linux user on the server used as traffic generator;
- GENERATOR_SERVER_USER_PASS: the user password on the server used as traffic generator;
- GENERATOR_SERVER_NAME: the name/IP of the first server used as traffic generator;
- CLICK_CORES: number of threads used by Click/FAJITA;
- CLICK_DEVICE: the PCIe address of the NIC used by Click/FAJITA;
- CLICK_EXECUTABLE: the absolute path to the- clickexecutable used by Click/FAJITA;
- QUEUEMEM_PATH: path in the Tofino to the Queue-Mem code and- setup.pyfile;
- FWD_PATH: path in the Tofino to the- bq_forwardercode and- setup_bq_forwarder.pyfile;
- MULTICAST_PATH: path in the Tofino to the- bq_mcastcode and- setup_bq_mcast.pyfile;
- NF_PATH: path in the server where the FAJITA scripts are located;
- GENERATOR_PATH: path in the server where the FastClick scripts contained in the- generatorfolder are located;
- TREX_PATH: path in the server where the TRex bin is located;
- TREX_CONFIG_PATH: path in the server where the TRex scripts contained in the- trexfolder are located;
- MULTICAST_TOFINO_SDE: SDE path in the Tofino where- bq_mcastis installed;
- QUEUEMEM_TOFINO_SDE: SDE path in the Tofino where Queue-Mem is installed.
After configuring the project, you can run all the experiments by typing the following command:
sh run_all_experiments.sh -d <results_path> -n <n_of_runs>You can also run a single experiment by running the specific N_run_experiment_*.sh file.
Check the content of the file for the specific parameters to pass.
After you gathered all the results, you can plot them by running the following command:
python3 plot.py <results_path> <figures_path> <mcast>