Skip to content

Containerlab on Windows#

By leveraging the Windows Subsystem Linux (aka WSL) you can run Containerlabs on Windows almost like on Linux. WSL allows Windows users to run a lightweight Linux VM inside Windows, and we can leverage this to run containerlab.

There are two primary ways of running containerlab on Windows:

  1. Running containerlab directly in the WSL VM.
  2. Running containerlab inside a Devcontainer inside WSL.

We will cover both of these ways in this document, but first let's quickly go over the WSL setup.

Setting up WSL#

WSL-Containerlab, WHAT?

Hey, before you dive into the WSL details, you might want check out a project that the relentless team of @kaelemc, @FloSch62, and @hyposcaler-bot worked on over 900 Discord messages.

It is coined as WSL-Containerlab and can be the best Containerlab-on-WSL experience if you can install WSL 2.4.4+ version. Read more at project's README.

WSL takes the central role in running containerlabs on Windows. Luckily, setting up WSL is very easy, and there are plenty of resources online from blogs to YT videos explaining the bits and pieces. Here we will provide some CLI-centric1 instructions that were executed on Windows 11.

Windows and WSL version

The following instructions were tested on Windows 11 and WSL2. On Windows 10 some commands may be different, but the general idea should be the same.

First things first, open up a terminal and list the running WSL virtual machines and their versions:

wsl -l -v
  NAME      STATE           VERSION
* Ubuntu    Running         2

On this system we already have a WSL VM with Ubuntu OS running, which was created when we installed WSL on Windows. If instead of a list of WSL VMs you get an error, you need to install WSL first:

Installing WSL on Windows 11
wsl --install -d Debian #(1)!
  1. Installing a new WSL system will prompt you to choose a username and password.

If you performed a default WSL installation before, you are likely running an Ubuntu, and while it is perfectly fine to use it, we prefer Debian, so let's remove Ubuntu and install Debian instead:

Removing Ubuntu and installing Debian
wsl --unregister Ubuntu #(1)!
wsl --install -d Debian
  1. Unregistering a WSL VM will remove the VM. You should reference a WSL instance by the name you saw in the wsl -l -v command.

Once the installation is complete, you will enter the WSL shell, which is a regular Linux shell2.

It is recommended to reboot your Windows system after installing the WSL. When the reboot is done you have a working WSL system that can run containerlab, congratulations!

Installing docker and containerlab on WSL#

Now that we have a working WSL system, we can install docker and containerlab on it like we would on any Linux system.

WSL2 and Docker Desktop

If you have Docker Desktop3 installed on your Windows system, you need to ensure that it is not enabled for the WSL VM that we intend to use for containerlabs.
To check that your WSL system is "free" from Docker Desktop integration, run sudo docker version command and ensure that you have an error message saying that docker command is not found.

Check Docker Desktop settings to see how to disable Docker Desktop integration with WSL2 if the above command does not return an expected error.

We are going to use the quick setup script to install docker and containerlab, but since this script uses curl, we need to install it first:

sudo apt update && sudo apt -y install curl

and then run the quick setup script:

curl -sL https://containerlab.dev/setup | sudo -E bash -s "all"

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.

export SETUP_SSHD="false"

To complete installation and enable sudo-less docker command execution, please run newgrp docker or logout and log back in.

Now you should be able to run the docker version command and see the version of docker installed. That was easy, wasn't it?

The installation script also installs containerlab, so you can run clab version to see the version of containerlab installed. This means that containerlab is installed in the WSL VM and you can run containerlabs in a normal way, like you would on Linux.

Running VM-based routers inside WSL?

In Windows 11 with WSL2 it is now possible to enable KVM support. Let us know if that worked for you in our Discord.

Devcontainer#

Another convenient option to run containerlab on Windows (and macOS) is to use the Devcontainer feature that works great with VS Code and many other IDE's.

A development container (or devcontainer) allows you to use a container as a full-featured development environment. By creating the devcontainer.json4 file, you define the development environment for your project. Containerlab project maintains a set of pre-built multi-arch devcontainer images that you can use to run containerlabs.
It was initially created to power containerlab in codespaces, but it is a perfect fit for running containerlab on a wide range of OSes such as macOS and Windows.

Since the devcontainer works exactly the same way on Windows and macOS, please refer to the macOS section for the detailed documentation and a video walkthrough.

A few things to keep in mind when using devcontainers on windows:

  1. If using VS Code, you will need to install the server component in your WSL instance, this will require you to install wget, as VS Code installer requires it.

    sudo apt -y install wget
    

    Then you will be able to type code . in the cloned repository to open the project in VS Code.

  2. As with macOS, you will likely wish to use a Docker-outside-of-Docker method, where the devcontainer will have access to the images and containers from the WSL VM.

DevPod#

DevPod delivers a stellar User Experience on macOS5, but on Windows, it requires a bit more setup. We tried to make it as easy as possible by providing you with the WSL distribution with the necessary tools pre-installed.

When you install Containerlab WSL VM and DevPod, you will have to create the SSH provider in DevPod with the following settings:

pic

And that's it! You should now be able to use DevPod to run containerlabs on Windows.


  1. If you don't have a decent terminal emulator on Windows, install "Windows Terminal" from the Microsoft Store. 

  2. The kernel and distribution parameters can be checked as follows:

    roman@Win11:~$ uname -a
    Linux LAPTOP-H6R3238F 5.15.167.4-microsoft-standard-WSL2 #1 SMP Tue Nov 5 00:21:55 UTC 2024 x86_64 GNU/Linux
    

    roman@Win11:~$ cat /etc/os-release
    PRETTY_NAME="Debian GNU/Linux 12 (bookworm)"
    NAME="Debian GNU/Linux"
    VERSION_ID="12"
    
     

  3. Or any other desktop docker solution like Rancher Desktop, Podman Desktop, etc. 

  4. Follows the devcontainer specification 

  5. Almost a one-click solution 

Comments