Skip to content
Konstantinos Papadopoulos edited this page Feb 14, 2017 · 7 revisions

NSTAT: Automated stress tests for OPFNV/CPerf project

Automated tests present in this repo are planned to be integrated within the CPerf SDN Controller Performance Testing platform. Progress of this work is available here.

Overview

The repository contains scripts for automatically running all SDN controller performance stress tests with the aid of the NSTAT and friends suite. NSTAT friends are considered the

[1] NSTAT-SDN-Controllers project,

[2] the NSTAT SouthBound emulators MTCbench, Multinet projects,

[3] the NSTAT NorthBound emulator NSTAT-NB-Generator project,

For running the tests on a host machine, the tools and steps below should be installed and followed respectively.

Essential tools

Installation steps

Clone the NSTAT:OPFNV/CPerf on the host machine.

  • Step 1
git clone https://github.com/intracom-telecom-sdn/nstat-cperf.git nstat-cperf
git --git-dir=nstat-cperf/.git --work-tree=nstat-cperf checkout v.1.0
  • Step 2

Give read/write/execute permissions for any user in /opt

chmod 777 -R /opt
  • Step 3

Give non-root access to docker daemon

  • Add the docker group if it doesn't already exist sudo groupadd docker

  • Add the connected user "${USER}" to the docker group. Change the user name to match your preferred user

sudo gpasswd -a ${USER} docker
  • Restart the Docker daemon:
sudo service docker restart
  • Step 4

Change the following system configuration parameters on the host machine by editing the system files as mentioned below (valid for Ubuntu/Centos distros)

  • /etc/security/limits.conf
  • soft nofile 1000000
  • hard nofile 1000000
  • /etc/sysctl.conf
  • net.ipv4.ip_forward = 1
  • kernel.nmi_watchdog=0
  • kernel.pty.max = 4096
  • fs.file-max = 26233259
  • net.core.wmem_max = 12582912
  • net.core.rmem_max = 12582912

Run the tests

At the moment stress test json input files are provided for two different versions of the OpenDaylight SDN controller, Beryllium and Boron. These files are stored under

./$NSTAT_CPERF_DIR/fnctl_tests/
./$NSTAT_CPERF_DIR/stress_tests/

directories. It is recommmended to start with functional testing, since no intensive memory resources are required on the host side. 8Gb RAM memory (minimum) present on the host machine is recommended. Functional tests run end to end producing finally the test report in HTML form.

Once the user becomes familiar with functional testing, stress testing is nothing more than having the same input json files but with greater dimensions. This can be validated by looking at the diffs between ie.the json input files

  • /fnctl_tests/beryllium/beryllium_nb_active_scalability_multinet.json,
  • /stress_tests/beryllium/beryllium_nb_active_scalability_multinet.json.

Functional testing

Stress testing

Test execution sequence

An example of a test execution sequence is shown in the Figure below.

Every cperf_ci.sh script and given the aforementioned *.json file will deploy the proper number of containers as defined within docker-compose.yml.

For example, the docker-compose.yml located under /fnctl_tests/boron/sb_mtcbehch defines three containers

  • nstat,
  • controller,
  • mtcbench

which will be created out of the

  • intracom/nstat:proxy
  • intracom/nstat-sdn-controllers:proxy
  • intracom/mtcbench:proxy

images. These images are prebuilt, and located under hub.dockerhub/intracom. For users sitting behind a proxy new images must be built. Detailed instructions are provided in the NSTAT installation section. In any other case, the images to be used are labeled latest as shown in the example below

  • intracom/nstat:latest
  • intracom/nstat-sdn-controllers:latest
  • intracom/mtcbench:latest

All containers are interconnected with IPs defined within the docker-compose.yml.

Once the docker containers are up and running, the test input *.json is copied on to the NSTAT container

docker cp $CONFIG_FILENAME.json nstat:$NSTAT_WORKSPACE

and a docker-exec command follows

docker exec -i nstat /bin/bash -c
...

which will execute the proper test. Once the test is over, the results folder is copied back to the HOST and all containers are killed. The user can then navigate to the RESULTS_DIR directory to check all test results. Parameters NSTAT_WORKSPACE, RESULTS_DIR are defined within the cperf_ci.sh script.

Test execution

Contact and Support

For issues regarding NSTAT, please use the issue tracking section. For any other questions and feedback, contact us at [email protected].