Deployment

Omniperf is broken into two installation components:

  1. Omniperf Client-side (Required)

    • Provides core application profiling capability

    • Allows collection of performance counters, filtering by hardware block, dispatch, kernel, etc

    • CLI based analysis mode

    • Stand alone web interface for importing analysis metrics

  2. Omniperf Server-side (Optional)

    • Mongo DB backend + Grafana instance

    • Packaged in a Docker container for easy setup

Determine what you need to install based on how you would like to interact with Omniperf. See the decision tree below to help determine what installation is right for you.

Omniperf Installation Decision Tree


Client-side Installation

Omniperf client-side requires the following basic software dependencies prior to usage:

  • Python (>=3.8)

  • CMake (>= 3.19)

  • ROCm (>= 5.7.1)

In addition, Omniperf leverages a number of Python packages that are documented in the top-level requirements.txt file. These must be installed prior to Omniperf configuration.

Optional packages

If you would like to build Omniperf as a developer, consider these additional requirements:

Requirement file

Description

requirements-doc.txt

Python packages required to build docs from source

requirements-test.txt

Python packages required to run Omniperf’s CI suite via PyTest

The recommended procedure for Omniperf usage is to install into a shared file system so that multiple users can access the final installation. The following steps illustrate how to install the necessary python dependencies using pip and Omniperf into a shared location controlled by the INSTALL_DIR environment variable.

Configuration variables

The following installation example leverages several CMake project variables defined as follows:

Variable

Description

CMAKE_INSTALL_PREFIX

controls install path for Omniperf files

PYTHON_DEPS

provides optional path to resolve Python package dependencies

MOD_INSTALL_PATH

provides optional path for separate Omniperf modulefile installation

A typical install will begin by downloading the latest release tarball available from the Releases section of the Omniperf development site. From there, untar and descend into the top-level directory as follows:

$ tar xfz omniperf-v2.0.0.tar.gz
$ cd omniperf-v2.0.0

Next, install Python dependencies and complete the Omniperf configuration/install process as follows:

# define top-level install path
$ export INSTALL_DIR=<your-top-level-desired-install-path>

# install python deps
$ python3 -m pip install -t ${INSTALL_DIR}/python-libs -r requirements.txt

# configure Omniperf for shared install
$ mkdir build
$ cd build
$ cmake -DCMAKE_INSTALL_PREFIX=${INSTALL_DIR}/2.0.0 \
        -DPYTHON_DEPS=${INSTALL_DIR}/python-libs \
        -DMOD_INSTALL_PATH=${INSTALL_DIR}/modulefiles ..

# install
$ make install

Tip

You may require sudo during the final install step if you do not have write access to the chosen install path.

After completing these steps, a successful top-level installation directory looks as follows:

$ ls $INSTALL_DIR
modulefiles  2.0.0  python-libs

Execution using modulefiles

The installation process includes creation of an environment modulefile for use with Lmod. On systems that support Lmod, a user can register the Omniperf modulefile directory and setup their environment for execution of Omniperf as follows:

$ module use $INSTALL_DIR/modulefiles
$ module load omniperf
$ which omniperf
/opt/apps/omniperf/2.0.0/bin/omniperf

$ omniperf --version
ROC Profiler:   /opt/rocm-5.1.0/bin/rocprof

omniperf (v2.0.0)

Tip

Users relying on an Lmod Python module locally may wish to customize the resulting Omniperf modulefile post-installation to include additional module dependencies.

Execution without modulefiles

To use Omniperf without the companion modulefile, update your PATH settings to enable access to the command-line binary. If you installed Python dependencies in a shared location, update your PYTHONPATH config as well:

export PATH=$INSTALL_DIR/2.0.0/bin:$PATH
export PYTHONPATH=$INSTALL_DIR/python-libs

rocProf

Omniperf relies on a rocProf binary during the profiling process. Normally the path to this binary will be detected automatically, but it can also be overridden via the setting the optional ROCPROF environment variable to the path of the binary the user wishes to use instead.


Server-side Setup

Note

Server-side setup is not required to profile or analyze performance data from the CLI. It is provided as an additional mechanism to import performance data for examination within a detailed Grafana GUI.

Omniperf server-side requires the following basic software dependencies prior to usage:

The recommended process for enabling the server-side of Omniperf is to use the provided Docker file to build the Grafana and MongoDB instance.

Once you have decided which machine you would like to use to host the Grafana and MongoDB instance, please follow the set-up instructions below.

Install MongoDB Utils

Omniperf uses mongoimport to upload data to Grafana’s backend database. Install for Ubuntu 20.04 is as follows:

$ wget https://fastdl.mongodb.org/tools/db/mongodb-database-tools-ubuntu2004-x86_64-100.6.1.deb
$ sudo apt install ./mongodb-database-tools-ubuntu2004-x86_64-100.6.1.deb

Installation instructions for alternative distributions can be found here

Persistent Storage

The user will also bind MongoDB to a directory on the host OS to create a local backup in case of a crash or reset. In the Docker world, this is known as “creating a persistent volume”:

$ sudo mkdir -p /usr/local/persist && cd /usr/local/persist/
$ sudo mkdir -p grafana-storage mongodb
$ sudo docker volume create --driver local --opt type=none --opt device=/usr/local/persist/grafana-storage --opt o=bind grafana-storage
$ sudo docker volume create --driver local --opt type=none --opt device=/usr/local/persist/mongodb --opt o=bind grafana-mongo-db

Build and Launch

We are now ready to build our Docker file. Navigate to your Omniperf install directory to begin.

$ sudo docker-compose build
$ sudo docker-compose up -d

TCP ports for Grafana (4000) and MongoDB (27017) in the docker container are mapped to 14000 and 27018, respectively, on the host side.

Tip

In the event that your Grafana or MongoDB instance crash fatally, you can always restart the server. Just navigate to your install directory and run:

$ sudo docker-compose down
$ sudo docker-compose up -d

Setup Grafana Instance

Once you have launched your docker container you should be able to reach Grafana at http://<host-ip>:14000. The default login credentials for the first-time Grafana setup are:

  • Username: admin

  • Password: admin

Grafana Welcome Page

MongoDB Datasource Configuration

The MongoDB Datasource must be configured prior to the first-time use. Navigate to Grafana’s Configuration page (shown below) to add the Omniperf Data connection.

Omniperf Datasource Config

Configure the following fields in the datasource settings:

  • HTTP URL: set to http://localhost:3333

  • MongoDB URL: set to mongodb://temp:temp123@\<host-ip>:27018/admin?authSource=admin

  • Database Name: set to admin

After properly configuring these fields click Save & Test (as shown below) to make sure your connection is successful.

Note to avoid potential DNS issue, one may need to use the actual IP address for the host node in the MongoDB URL.

Datasource Settings

Omniperf Dashboard Import

From CreateImport, (as shown below) upload the dashboard file, /dashboards/Omniperf_v2.0.0_pub.json, from the Omniperf tarball.

Edit both the Dashboard Name and the Unique Identifier (UID) to uniquely identify the dashboard he/she will use. Click Import to finish the process.

Import Dashboard

Using your dashboard

Once you have imported a dashboard you are ready to begin! Start by browsing available dashboards and selecting the dashboard you have just imported.

Opening your dashboard

Remember, you will need to upload workload data to the DB backend before analyzing in your Grafana interface. We provide a detailed example of this in our Analysis section.

After a workload has been successfully uploaded, you should be able to select it from the workload dropdown located at the top of your Grafana dashboard.

Selecting Grafana workload

For more information on how to use the Grafana interface for analysis please see the Grafana section in the Analyze Mode tab.