The Statistics Collection Tool project provides the 'stats-collect' command-line tool. This tool collects system statistics and telemetry, and visualizes them. It’s for debugging and tracing purposes only. It is for lab usage, not for production usage. The users are software engineers debugging a problem in the Linux operating system.
Note, while 'stats-collect' is available via OS packages, they typically do not provide the latest version. Use the "pip" installation method to get the latest 'stats-collect' version.
Note, the 'stats-collect' project is dependent on the 'pepc' tool.
This means that you will need to install 'pepc' before installing 'stats-collect'. Please check the 'pepc' documentation for information on how to install it.
'stats-collect' is available on Fedora 38 and Fedora 39. To install 'stats-collect', run
sudo dnf install stats-collect
Fedora packages are maintained by Ali Erdinç Köroğlu [email protected].
In case of Fedora 37 or older Fedora, use the 'pip' installation method.
We do not provide CentOS/Ubuntu/Debian packages, so you'll need to use the 'pip' installation method.
Run the following command:
sudo pip3 install --upgrade git+https://github.com/intel/stats-collect.git@release
This command will download 'stats-collect' from the 'release' branch of the git repository and install it to the system.
The other way of doing this is by first cloning the git repository and running
git clone https://github.com/intel/stats-collect.git --branch release stats-collect
cd stats-collect
pip3 install --upgrade .
Note, 'stats-collect' has to be run with superuser (root) privileges in many cases, and if you install it with the '--user' option of 'pip3', it won't work "out of the box". This is why we do not recommend using '--user'.
Below outlines basic local usage of the 'stats-collect' tool involving how to collect and visualise statistics.
All of the commands listed below can be used in conjunction with the -h
option to learn more about
the command and other options that can be used with it.
Start statistics collection using the stats-collect start
command.
A command must be passed to stats-collect start
to run on the system during the test (e.g. sleep 30
is used in the example below).
Note that below the optional -o
argument is used to specify an output directory.
stats-collect start -o stats-result 'sleep 30'
Generate an HTML report to visualise the statistics collected using stats-collect start
.
stats-collect report stats-result
To view the report, open the 'index.html' file in the report directory in a browser.
stats-collect
can be used to collect statistics on a remote system. Generally, the process is very
similar to the local usage but there are some differences.
Please note: in the following steps, the name of the system to measure should be used. For documentation purposes, the example comands below will use a placeholder name 'SUTNAME'. Therefore, please replace any instances of 'SUTNAME' with the name of the system you are trying to measure before running the commands.
Before collecting statistics with 'stats-collect' start, 'stats-collect deploy' should be used. This is to deploy the 'stats-collect' helpers to the system which are required to collect statistics.
stats-collect deploy -H SUTNAME
The statistics collection step is very similar to the equivalent step in local usage. However it
differs because it requires the host option -H SUTNAME
(like in the previous deployment step).
See local usage, for more information on the other elements of this command.
stats-collect start -H SUTNAME -o stats-result 'sleep 30'
Generating a report for remote data works exactly the same way as locally. Remember to make sure
that the result directory you specify is the same as the directory passed as the output directory
the statistics collection step (using the -o
option).
stats-collect report stats-result
For more information, documentation is available for each 'stats-collect' command accordingly:
stats-collect deploy
- Documentationstats-collect start
- Documentationstats-collect report
- Documentation
- Artem Bityutskiy [email protected] - original author, project maintainer.
- Antti Laakso [email protected] - contributor, project maintainer.
- Adam Hawley [email protected] - contributor.
- Niklas Neronin [email protected] - contributor.