- Python 3.8 or newer
- Linux (cf. Kernel Requirements below for details)
- Access to cgroups (cf. Setting up Cgroups below for details)
- x86 or ARM machine (please contact us for other architectures)
The following packages are optional but recommended dependencies:
- cpu-energy-meter will let BenchExec measure energy consumption on Intel CPUs.
- fuse-overlayfs (version 1.10 or newer) allows to use the overlay directory mode for containers in cases where the kernel-based overlayfs does not work.
- libseccomp2 provides better container isolation.
- LXCFS provides better container isolation.
- coloredlogs provides nicer log output.
- pqos_wrapper and pqos library
provide isolation of L3 cache and measurement of cache usage and memory bandwidth
(only in
benchexec
). - pystemd allows BenchExec to automatically configure cgroups on systems with systemd and cgroups v2.
Note that the table-generator
utility requires only Python and works on all platforms.
For installing BenchExec on Debian or Ubuntu we recommend installing from our PPA:
sudo add-apt-repository ppa:sosy-lab/benchmarking
sudo apt install benchexec
Alternatively, you can download our .deb
package from GitHub
and install manually (note that the leading ./
is important, otherwise apt
will not find the package):
apt install --install-recommends ./benchexec_*.deb
On Ubuntu 21.10 and newer with the default cgroup config, this is all.
On older Ubuntu versions or those configured for cgroups v1,
our package automatically configures the necessary cgroup permissions.
Then add the users that should be able to use BenchExec to the group benchexec
(group membership will be effective after the next login of the respective user):
adduser <USER> benchexec
Afterwards, please check whether everything works or whether additional settings are necessary as described below.
Note that pqos_wrapper is currently not available as a Debian package and needs to be installed manually according to its documentation.
For NixOS 24.05 and later, refer to the options:
programs.benchexec.*
to configure BenchExec. The optional dependencies cpu-energy-meter, pqos_wrapper, and LXCFS as well as kernel module loading for access to MSR registers will all be enabled with BenchExec by default. To opt out, set the respective*.enable
option tofalse
explicitly.programs.cpu-energy-meter.*
to configure the optional dependency cpu-energy-meter.programs.pqos-wrapper.*
to configure the optional dependency pqos_wrapper.virtualisation.lxc.lxcfs.*
to configure the optional dependency LXCFS.hardware.cpu.x86.msr
to configure access to MSR registers, by default for members of the groupmsr
.users.users.<name>.extraGroups
to add user accounts extra groups such asmsr
(required for both cpu-energy-meter and pqos_wrapper). Note that users are NOT added tomsr
by default. This decision is opt-in for your security.
For example:
{
programs.benchexec = {
enable = true;
users = [ "<USER>" ];
};
users.users."<USER>".extraGroups = [ "msr" ];
}
For other distributions we recommend to use the Python package installer pip. To automatically download and install the latest stable version and its dependencies from the Python Packaging Index with pip, run this command:
sudo pip3 install benchexec[systemd] coloredlogs
You can also install BenchExec only for your user with
pip3 install --user benchexec[systemd] coloredlogs
In the latter case you probably need to add the directory where pip installs the commands
to the PATH environment by adding the following line to your ~/.profile
file:
export PATH=~/.local/bin:$PATH
Of course you can also install BenchExec in a virtualenv if you are familiar with Python tools.
On systems without systemd you can omit the [systemd]
part.
Please make sure to configure cgroups as described below and install cpu-energy-meter, fuse-overlayfs, libseccomp2, LXCFS, and pqos_wrapper if desired.
Please refer to the dedicated guide for the necessary steps to install BenchExec inside a container.
IMPORTANT: In any case, cgroups with all relevant controllers need to be available on the host system.
To install the latest development version from the GitHub repository, run this command:
pip3 install --user git+https://github.com/sosy-lab/benchexec.git coloredlogs
It is useful to install the system package python3-lxml
before,
otherwise pip will try to download and build this module,
which needs a compiler and several development header packages.
Please make sure to configure cgroups as described below and install cpu-energy-meter, fuse-overlayfs, libseccomp2, LXCFS, and pqos_wrapper if desired.
To execute benchmarks and reliably measure and limit their resource consumption, BenchExec requires that the user which executes the benchmarks can create and modify cgroups (see below for how to allow this).
If you are using an Ubuntu version that is still supported, everything else should work out of the box. For other distributions, please read the following detailed requirements.
Except on Ubuntu, the full feature set of BenchExec is only usable on Linux 5.11 or newer, so we suggest at least this kernel version. And if your system is using cgroups v2 (cf. below), the full feature set requires Linux 5.19 or newer.
On kernels older than 5.11, you need to avoid using the kernel-based overlay filesystem (cf. below), all other features are supported. However, we strongly recommend to use at least Linux 4.14 or newer because it reduces the overhead of BenchExec's memory measurements and limits. For even older kernel versions, please read our previous documentation with more details.
Using BenchExec on kernels without NUMA support is not guaranteed to work (but this is enabled by all common distributions).
In container mode (i.e., always except when using --no-container
),
BenchExec uses two main kernel features
that are not usable on all distributions by default:
-
User Namespaces: This is available on most distros (the kernel option is
CONFIG_USER_NS
), but many distributions disable this feature for regular users, so the system administrator needs to enable it. On Debian or Arch it can be necessary to enable this feature withsudo sysctl -w kernel.unprivileged_userns_clone=1
or a respective entry in/etc/sysctl.conf
. On CentOS it can be necessary to enable this feature withsudo sysctl -w user.max_user_namespaces=10000
or a respective entry in/etc/sysctl.conf
(the exact value is not important). On Ubuntu, we recommend to use our Ubuntu package, which takes care of this. Alternatively, on 24.04 or newer one can enable this feature withsysctl -w kernel.apparmor_restrict_unprivileged_userns=0
or a respective entry in/etc/sysctl.conf
. -
Unprivileged Overlay Filesystem: This is only available since Linux 5.11 (kernel option
CONFIG_OVERLAY_FS
), but also present in all Ubuntu kernels, even older ones. Users of older kernels on other distributions can still use container mode, but have to install fuse-overlayfs or choose a different mode of mounting the file systems in the container, e.g., with--read-only-dir /
(cf. container configuration). Note that the kernel-based overlayfs does not support some specific configurations (such as the default mode of overlay for/
), so fuse-overlayfs is often useful or required anyway.
If container mode does not work, please check the common problems.
This depends on whether your system is using cgroups v1 or v2.
To find out, please check whether /sys/fs/cgroup/cgroup.controllers
exists.
If yes, you are using v2, otherwise v1
(for the purpose of BenchExec, a hybrid usage of v1 and v2 counts as v1).
Then please follow the instructions from the appropriate subsection and the instructions for testing and troubleshooting.
Note that support for cgroups v2 is available only since BenchExec 3.18
and has received less testing than using cgroups v1 so far.
If you are on a distribution with cgroups v2 and want to switch to cgroups v1,
you can switch back to cgroups v1 for now by putting
systemd.unified_cgroup_hierarchy=0
on the kernel command line.
On Debian/Ubuntu, this could be done with the following steps and rebooting afterwards:
echo 'GRUB_CMDLINE_LINUX_DEFAULT="${GRUB_CMDLINE_LINUX_DEFAULT} systemd.unified_cgroup_hierarchy=0"' | sudo tee /etc/default/grub.d/cgroupsv1-for-benchexec.cfg
sudo update-grub
Furthermore, with cgroups v2 Linux 5.19 or newer is required in order to have memory measurements.
This applies for example for Ubuntu 21.10 and newer, Debian 11 and newer, and most other current Linux distributions.
If you installed the Ubuntu/Debian package, everything should be taken care of and no manual steps are necessary. Otherwise, follow these instructions.
By default, not all cgroups are delegated to each user,
so only a restricted feature set of BenchExec would be available.
To enabled delegation of all cgroup features, run
sudo systemctl edit [email protected]
, insert the following lines, save and quit:
[Service]
# For BenchExec
Delegate=yes
Apart from this one-time setup,
BenchExec can use systemd to automatically take care of any necessary cgroup configuration,
so no manual configuration is necessary.
However, the Python package pystemd
needs to be installed,
which happens automatically if you installed benchexec[systemd]
via pip.
If missing, install the package with sudo apt install python3-pystemd
or pip install pystemd
according to how you installed BenchExec.
BenchExec also works without pystemd
if you start BenchExec inside its own cgroup.
The easiest way to do so is using systemd-run
:
systemd-run --user --scope --slice=benchexec -p Delegate=yes benchexec ...
If you want to use systemd to pre-configure the cgroups that BenchExec uses
(e.g., influence the allowed CPU cores etc.),
you can do so by configuring benchexec.slice
in the user-specific systemd instance(s)
(all cgroups that BenchExec creates will be inside this systemd slice).
This is possible if you ensure manually that BenchExec is started in its own cgroup (i.e., a cgroup with no other processes inside). We recommend using systemd, though.
This applies to Ubuntu 21.04 and older and Debian 10 and older (if the Debian package for BenchExec was used).
Our Debian package should have configured everything automatically.
Just add your user to the group benchexec
and reboot:
adduser <USER> benchexec
Most distributions today use systemd, and systemd makes extensive usage of cgroups and claims that it should be the only process that accesses cgroups directly. Thus it would interfere with the cgroups usage of BenchExec.
By using a dummy service we can let systemd create an appropriate cgroup for BenchExec and prevent interference. The following steps are necessary:
-
Decide which set of users should get permissions for cgroups. Our recommendation is to create a group named
benchexec
withgroupadd benchexec
and add the respective users to this group. Note that users need to logout and login afterwards to actually get the group membership. -
Put the file
benchexec-cgroup.service
into/etc/systemd/system/
and enable the service withsystemctl daemon-reload; systemctl enable --now benchexec-cgroup
.By default, this gives permissions to users of the group
benchexec
, this can be adjusted in theEnvironment
line as necessary.
By default, BenchExec will automatically attempt to use the cgroup
system.slice/benchexec-cgroup.service
that is created by this service file.
If you use a different cgroup structure,
you need to ensure that BenchExec runs in the correct cgroup
by executing the following commands once per terminal session:
echo $$ > /sys/fs/cgroup/cpuset/<CGROUP>/tasks
echo $$ > /sys/fs/cgroup/cpuacct/<CGROUP>/tasks
echo $$ > /sys/fs/cgroup/memory/<CGROUP>/tasks
echo $$ > /sys/fs/cgroup/freezer/<CGROUP>/tasks
In any case, please check whether everything works or whether additional settings are necessary as described below.
The cgroup virtual file system is typically mounted at or below /sys/fs/cgroup
.
If it is not, you can mount it with
sudo mount -t cgroup cgroup /sys/fs/cgroup
To give all users on the system the ability to create their own cgroups, you can use
sudo chmod o+wt,g+w /sys/fs/cgroup/
Of course permissions can also be assigned in a more fine-grained way if necessary.
Alternatively, software such as cgrulesengd
from
the libcgroup project
can be used to setup the cgroups hierarchy.
Note that cgrulesengd
might interfere with the cgroups of processes,
if configured to do so via cgrules.conf
.
This can invalidate the measurements.
BenchExec will try to prevent such interference automatically,
but for this it needs write access to /run/cgred.socket
.
It may be that your Linux distribution already mounts the cgroup file system
and creates a cgroup hierarchy for you.
In this case you need to adjust the above commands appropriately.
To optimally use BenchExec,
the cgroup controllers cpuacct
, cpuset
, freezer
, and memory
should be mounted and usable,
i.e., they should be listed in /proc/self/cgroups
and the current user
should have at least the permission to create sub-cgroups of the current cgroup(s)
listed in this file for these controllers.
In any case, please check whether everything works or whether additional settings are necessary as described below.
After installing BenchExec and configuring cgroups if appropriate, please run
python3 -m benchexec.check_cgroups
This will report warnings and exit with code 1 if something is missing. If you find that something does not work, please check the following list of solutions.
For cgroups v1:
If your machine has swap, cgroups should be configured to also track swap memory.
This is turned off by several distributions.
If the file memory.memsw.usage_in_bytes
does not exist in the directory
/sys/fs/cgroup/memory
(or wherever the cgroup file system is mounted),
this needs to be enabled by setting swapaccount=1
on the command line of the kernel.
On Ubuntu, you can for example set this parameter by creating the file
/etc/default/grub.d/swapaccount-for-benchexec.cfg
with the following content:
GRUB_CMDLINE_LINUX_DEFAULT="${GRUB_CMDLINE_LINUX_DEFAULT} swapaccount=1"
Then run sudo update-grub
and reboot.
On other distributions, please adjust your boot loader configuration appropriately.
In some Debian kernels (and those derived from them, e.g. Raspberry Pi kernel),
the memory cgroup controller is disabled by default, and can be enabled by
setting cgroup_enable=memory
on the kernel command line, similar to
swapaccount=1
above.
Please refer to the development instructions.