Building CBL-Delridge, Microsoft's other Linux distro
Microsoft has another Linux distro you probably haven't heard of. You can easily build it and even import it into WSL.
data:image/s3,"s3://crabby-images/8b765/8b765b28760708109fab950910b8811062768f70" alt="Building CBL-Delridge, Microsoft's other Linux distro"
Microsoft maintains a handful of Linux distributions. You may have heard of CBL-Mariner:
data:image/s3,"s3://crabby-images/d38cd/d38cd13a7d3112d6beba50cdd2dcd9c80e788ff1" alt=""
CBL-Mariner is used across Microsoft, including Azure and to power WSLg on WSL 2.
You may also have heard of Microsoft's earlier networking Linux distro, SONiC:
data:image/s3,"s3://crabby-images/42431/424312b5805606d0e291a8ea5c12c88ddf4e14b1" alt="".svg/28px-Free_and_open-source_software_logo_(2009).svg.png)
data:image/s3,"s3://crabby-images/15a09/15a09d88b523ca90f3b3a0aeeb0b9ce547b6c097" alt=""
Did you know Microsoft also maintains yet another Linux distribution, CBL-Delridge?
Searches for it on Google bring up...CBL-Mariner and a mention of CBL-Delridge on my Microsoft Open Source timeline:
data:image/s3,"s3://crabby-images/8d5b1/8d5b163b36b22446a6b0e571665b0d3ce02009ec" alt=""
CBL-Delridge is used to power Azure's Cloud Shell:
data:image/s3,"s3://crabby-images/afcf1/afcf12cfd5c9fb2b2ccb2cd3185b0572369d00ca" alt=""
Unlike CBL-Mariner, which is built from scratch, CBL-Delridge is based on Debian, specifically version 10, codenamed Buster.
The current version of CBL-Delridge, or CBL-D for short, is coincidentally also version 10, codenamed Quinault.
The apt package repositories for CBL-D are public and therefore it is possible to build our own image of CBL-D for our own purposes and even import it into WSL.
First, we need debootstrap. debootstrap allows you to bootstrap Debian-family distributions from apt repositories. deboostrap can be found in most other distro package repositories, including openSUSE.
On openSUSE install debootstrap with:
sudo zypper in -y debootstrap
data:image/s3,"s3://crabby-images/0a182/0a182347a346a785b4a0130899fb6e597c63bf1a" alt=""
Next we need to create a chroot, a new root directory folder to bootstrap the CBL-D image into:
mkdir /tmp/chroot
data:image/s3,"s3://crabby-images/9817a/9817a8ed375aa67547c47946f3523747b6d9bebe" alt=""
Then we need to give debootstrap some very basic information about CBL-D. debootstrap includes this info for common Debian family distributions, including Debian, Kali, Ubuntu, and Devuan:
data:image/s3,"s3://crabby-images/1cb53/1cb53d5c679310f601a9d6e55722bbc5f2bca391" alt=""
No Quinault here though. But Quinault is based on Debian Buster, so we can just copy the debootstrap script for Buster and debootstrap will find it and use it:
sudo cp /usr/share/debootstrap/scripts/buster /usr/share/debootstrap/scripts/quinault
data:image/s3,"s3://crabby-images/28726/28726c2a5bd1b147271eaaa813f8a7096ed7dad8" alt=""
Next, we fire up debootstrap with:
sudo debootstrap --arch "amd64" --include=gnupg,sudo,nano quinault /tmp/chroot https://packages.microsoft.com/repos/cbl-d/
Our command specifies:
--arch "amd64"
because we are building for amd64. It is possible to cross-compile with debootstrap but it can be messy.
--include=gnupg,sudo,nano
to include these additional packages on top of the base Quinault image.
quinault
is the version name of our distro and the reason we copied the debootstrap script before.
/tmp/chroot
is where we want to bootstrap the image, into the new root filesystem.
https://packages.microsoft.com/repos/cbl-d/
is the location of the CBL-D apt repository.
data:image/s3,"s3://crabby-images/4c249/4c2495a9383e8006ddc6b01061dda1c569c32a64" alt=""
If successful, we land at:
data:image/s3,"s3://crabby-images/0d822/0d822ed5cd1a7500563eb4ac15319624efb1842f" alt=""
The contents of /tmp/chroot
look like the root folder of any Linux distro:
data:image/s3,"s3://crabby-images/79aaf/79aaf2a65279c068bff53bbaa2ebcc5272836126" alt=""
We have a few more steps to complete though to make this a functional distro image we can use.
Our base image includes https://packages.microsoft.com/repos/cbl-d
in it's apt sources.list file, but there is an additional repository for CBL-D published by Microsoft that contains Go, Python, and a handful of utilities.
Add the additional repository to sources.list with:
echo 'deb https://packages.microsoft.com/repos/cbl-d quinault-universe main' | sudo tee -a /etc/apt/sources.list > /dev/null
data:image/s3,"s3://crabby-images/8a6ae/8a6aef2c7cde607f643216fc59ebbfb15d04aee7" alt=""
The contents of /tmp/chroot/etc/apt/sources.list
should now include:
deb https://packages.microsoft.com/repos/cbl-d quinault main
deb https://packages.microsoft.com/repos/cbl-d quinault-universe main
Finally, we need to add the security keys for the Microsoft CBL-D apt repository, otherwise apt
cannot verify packages or perform upgrades. We do this by using the chroot
command to run apt-key
from inside our new chroot filesystem:
sudo chroot /tmp/chroot/ /usr/bin/apt-key adv --keyserver hkps://keyserver.ubuntu.com:443 --recv-keys EB3E94ADBE1229CF
This runs /usr/bin/apt-key
inside our chroot at /tmp/chroot
as if /tmp/chroot
was the root folder. It essentially runs the command on CBL-D inside CBL-D, even though it is just a folder on openSUSE.
data:image/s3,"s3://crabby-images/09819/09819437538c1ed5f38109b50ada2944a935640b" alt=""
Once we have imported the keys to apt to authenticate with the Microsoft repositories, we have a working image.
Now, we can play with CBL-D.
The easiest way to get started is to launch bash in the CBL-D chroot folder with:
sudo chroot /tmp/chroot/ /bin/bash
This is similar to how we used chroot
to run the apt-key
command, except this time spawning a shell we can explore with.
data:image/s3,"s3://crabby-images/16596/16596809c138a973019226bb1370cdc42b038ed9" alt=""
Now you are running as if /tmp/chroot
was the root directory, so running apt update
is going to check the Microsoft repository for upgrades for CBL-D, even here in a folder on openSUSE. You can exit the chroot with exit
to go back to your host distro:
data:image/s3,"s3://crabby-images/80707/8070724405d8cbe14c6162fadd3b8688ca0b03d3" alt=""
If you want to bundle up your chroot environment to import into WSL to play with, then we need to make a .tar.gz archive and then import with wsl.exe --import
. Make sure if you used the command above you exit the chroot and go back to your host distro.
We create a tar of the chroot by:
sudo tar -cpzf cbld-quinault.tar.gz -C /tmp/chroot/ .
sudo
here is necessary because of some of the permissions on the bootstrapped file system.
data:image/s3,"s3://crabby-images/e1e1f/e1e1f4b660ffc44355b1ebc919c38550be3062cc" alt=""
Then we can import it as a WSL distro, from inside WSL or separate PowerShell, with:
wsl.exe --import CBL-D "C:\WSL\CBL-D" cbld-quinault.tar.gz --version 2
This command tells WSL to import a distro with:
CBL-D
as the name, which you can call with wsl.exe -d CBL-D
or visible in Windows Terminal.
With the WSL files stored at C:\WSL\CBL-D
.
From our cbld-quinault.tar.gz
root filesystem archive.
As WSL 2 with --version 2
.
data:image/s3,"s3://crabby-images/f1a1a/f1a1a500a7edbc1dfe7d99dfe69a8ff03e939a29" alt=""
Then you can launch CBL-D on WSL with:
wsl.exe -d CBL-D
data:image/s3,"s3://crabby-images/0dba3/0dba37725c3a7d8d4bc4004afeb005f93910278f" alt=""
Or re-open Windows Terminal and it will be visible in the drop-down menu:
data:image/s3,"s3://crabby-images/c728d/c728da2cfedba2523c747f5f2ff9ee3d9cec922c" alt=""
CBL-D is an abbreviated version of Debian, so all of your favorite packages might not be present.
There are about 1554 as of writing, compared to 28392 in Debian 10. I have posted a list here, almost all console tools and the most basic X utilities.
data:image/s3,"s3://crabby-images/23603/23603dc6dbc477ccf284e8119cba9d97bbba3313" alt=""