Installation#
Containerlab is distributed as a Linux deb/rpm/apk package for amd64 and arm64 architectures and can be installed on any Debian- or RHEL-like distributive in a matter of a few seconds.
Pre-requisites#
The following requirements must be satisfied to let containerlab tool run successfully:
- A user should have
sudo
privileges to run containerlab. - A Linux server/VM1 and Docker installed.
- Load container images (e.g. Nokia SR Linux, Arista cEOS) that are not downloadable from a container registry. Containerlab will try to pull images at runtime if they do not exist locally.
Quick setup#
The easiest way to get started with containerlab is to use the quick setup script that installs all of the following components in one go (or allows to install them separately):
- docker (docker-ce), docker compose
- Containerlab (using the package repository)
gh
CLI tool
The script has been tested on the following OSes:
- Ubuntu 20.04, 22.04, 23.10, 24.04
- Debian 11, 12
- Red Hat Enterprise Linux 9
- CentOS Stream 9
- Fedora Server 40 (should work on other variants of Fedora)
- Rocky Linux 9.3, 8.8 (should work on any 9.x and 8.x release)
To install all components at once, run the following command on any of the supported OSes:
By default, this will also configure sshd on the system to increase max auth tries so unknown keys don't lock ssh attempts. This behaviour can be turned off by setting the environment variable "SETUP_SSHD" to "false" before running the command shown above. The environment variable can be set and exported with the command shown below.
To complete installation and enable sudo-less docker
command execution, please run newgrp docker
or logout and log back in.
To install an individual component, specify the function name as an argument to the script. For example, to install only docker
:
If you don't have your own shell configuration and want to have a slightly better bash PS1 prompt you can also run this script:
Log out and log back in to see the new two-line prompt in action:
Install script#
Containerlab can be installed using the installation script that detects the operating system type and installs the relevant package:
Note
Containerlab is distributed via deb/rpm packages, thus only Debian- and RHEL-like distributives can leverage package installation.
Other systems can follow the manual installation procedure.
Download and install the latest release (may require sudo
):
Download a specific version. Versions can be found on the Releases page.
Since the installation script uses GitHub API, users may hit the rate limit imposed by GitHub. To avoid this, users can pass their personal GitHub token as an env var to the installation script:
Package managers#
It is possible to install official containerlab releases via public APT/YUM repository.
Download .apk
package from Github releases.
Arch Linux users can download a package from this AUR repository.
Manual package installation
Alternatively, users can manually download the deb/rpm package from the Github releases page.
example:
# manually install latest release with package managers
LATEST=$(curl -s https://github.com/srl-labs/containerlab/releases/latest | sed -e 's/.*tag\/v\(.*\)\".*/\1/')
# with yum
yum install "https://github.com/srl-labs/containerlab/releases/download/v${LATEST}/containerlab_${LATEST}_linux_amd64.rpm"
# with dpkg
curl -sL -o /tmp/clab.deb "https://github.com/srl-labs/containerlab/releases/download/v${LATEST}/containerlab_${LATEST}_linux_amd64.deb" && dpkg -i /tmp/clab.deb
# install specific release with yum
yum install https://github.com/srl-labs/containerlab/releases/download/v0.7.0/containerlab_0.7.0_linux_386.rpm
The package installer will put the containerlab
binary in the /usr/bin
directory as well as create the /usr/bin/clab -> /usr/bin/containerlab
symlink. The symlink allows the users to save on typing when they use containerlab: clab <command>
.
Windows#
Containerlab runs on Windows powered by Windows Subsystem Linux (aka WSL), where you can run Containerlab directly or in a Devcontainer. Open up Containerlab on Windows documentation for more details.
Apple macOS#
Running containerlab on macOS is possible both on ARM (M1/M2/M3/etc) and Intel chipsets. For a long time, we had many caveats around M-chipsets on Macs, but with the introduction of ARM64-native NOSes like Nokia SR Linux and Arista cEOS, powered by Rosetta emulation for x86_64-based NOSes, it is now possible to run containerlab on ARM-based Macs.
Since we wanted to share our experience with running containerlab on macOS in details, we have created a separate - Containerlab on macOS - guide.
Container#
Containerlab is also available in a container packaging. The latest containerlab release can be pulled with:
To pick any of the released versions starting from release 0.19.0, use the version number as a tag, for example, docker pull ghcr.io/srl-labs/clab:0.19.0
Since containerlab itself deploys containers and creates veth pairs, its run instructions are a bit more complex, but still, it is a copy-paste-able command.
For example, if your lab files are contained within the current working directory - $(pwd)
- then you can launch containerlab container as follows:
docker run --rm -it --privileged \
--network host \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /var/run/netns:/var/run/netns \
-v /etc/hosts:/etc/hosts \
-v /var/lib/docker/containers:/var/lib/docker/containers \
--pid="host" \
-v $(pwd):$(pwd) \
-w $(pwd) \
ghcr.io/srl-labs/clab bash
Within the started container you can use the same containerlab deploy/destroy/inspect
commands to manage your labs.
Note
Containerlab' container command is itself containerlab
, so you can deploy a lab without invoking a shell, for example:
Manual installation#
If the linux distributive can't install deb/rpm packages, containerlab can be installed from the archive:
# get the latest available tag
LATEST=$(curl -s https://github.com/srl-labs/containerlab/releases/latest | \
sed -e 's/.*tag\/v\(.*\)\".*/\1/')
# download tar.gz archive
curl -L -o /tmp/clab.tar.gz "https://github.com/srl-labs/containerlab/releases/download/v${LATEST}/containerlab_${LATEST}_Linux_amd64.tar.gz"
# create containerlab directory
mkdir -p /etc/containerlab
# extract downloaded archive into the containerlab directory
tar -zxvf /tmp/clab.tar.gz -C /etc/containerlab
# (optional) move containerlab binary somewhere in the $PATH
mv /etc/containerlab/containerlab /usr/bin && chmod a+x /usr/bin/containerlab
Upgrade#
To upgrade containerlab
to the latest available version issue the following command2:
This command will fetch the installation script and will upgrade the tool to its most recent version. In case of GitHub rate limit, provide GITHUB_TOKEN
env var with your personal GitHub token to the upgrade command.
Or leverage apt
/yum
utilities if containerlab repo was added as explained in the Package managers section.
From source#
To build containerlab from source:
To build containerlab from source, clone the repository and issue go build
at its root.
When we release containerlab we use goreleaser project to build binaries for all supported platforms as well as the deb/rpm packages.
Users can install goreleaser
and do the same locally by issuing the following command:
Uninstall#
To uninstall containerlab when it was installed via installation script or packages:
SELinux#
When SELinux set to enforced mode containerlab binary might fail to execute with Segmentation fault (core dumped)
error. This might be because containerlab binary is compressed with upx and selinux prevents it from being decompressed by default.
To fix this:
sudo semanage fcontext -a -t textrel_shlib_t $(which containerlab)
sudo restorecon $(which containerlab)
or more globally: