WSL Web Developer Bootstrap with Fedora 33
I have been having a blast playing around with configuring Fedora 33 in Windows via Windows Subsystem for Linux, I didn’t know you could straight up import a Linux distro and use it.
In this guide I’ll go through the complete setup needed to go from initial install of Fedora 33 right through to running GUI tools like Cypress and Puppeteer!
There’s a great resource I found in Fedora Magazine and another post in Dev.to, the Dev.to one I haven’t tried as the first guide does all I need it to do so it’s there for reference if needed.
This is my bootstrap for getting set up with Fedora 33 and all the related bits of software I’ll need for wed development with it.
Prerequisites
If you haven’t already got Windows Subsystem for Linux Installed then take a look at the official guidance from Microsoft.
I’d also suggest checking out Nicky Muleman’s post on it.
Get Fedora 33 for use in WSL
First up! Importing the Fedora 33 distribution.
Credit to Jim Perrin for the original post in Fedora Magazine on this.
Get the Dockerhub container image which is what I’ll be using for the
Linux instance, this is because Fedore doesn’t ship with rootfs so
I’m jacking this one from GitHub.
I’ll download the image and put it on my C drive in a distros folder.
The file is downloaded as a *.tar.xz file, I need to extract this so
it’s a *.tar file, I use 7zip to do that.
Import into WSL
Time to import the *.tar into WSL, I’ve already created a distros
folder on my C drive, now to point PowerShell to the file and import:
1wsl --import Fedora-33 C:\Users\scott\distros\ C:\Users\scott\distros\fedora-33.20201230-x86_64.tarTo break down that command, wsl is clear what that is hopefully,
with the --import denoting that what is being imported is called
Fedora-33 and it should live in the C:\Users\scott\distros\
folder, and the place to import from is
C:\Users\scott\distros\fedora-33.20201230-x86_64.tar.
Now to check out the installed versions available on my machine with
wsl -l -v, I’ve removed all the other Linux installs I have for
brevity but leaving Ubuntu there with the * next to it denoting it
as the default:
1# the l is for list2# v is for verbose 🤷♀️3# this is the long version => wsl --list --verbose4PS C:\Windows\system32> wsl -l -v5  NAME                  STATE           VERSION6* Ubuntu                Stopped         27  Fedora-33             Running         2Update and install core packages
Now it’s imported I can access it in PowerShell with:
1wsl -d Fedora-33This is the root user so I’ll need to my user account in a minute
first up though it’s the update dance we alway do in Linux, with
Fedora it’s dnf you use in place of apt like what’s used in
Ubuntu.
1# update all the things2dnf -y update3# install core packages4dnf install -y wget curl sudo ncurses dnf-plugins-core dnf-utils passwd findutilsThese are what’re recommended on Jim’s post so I’m going with this for now, I’ll add additional packages once I have created my user details.
Add my user
So, my user is scott if you’re following along you’ll need to change
that.
1# create user and add them to sudoers list2useradd -G wheel scott3# set password for user4passwd scottTime to exit this shell and go back in as my newly created user to check the credentials.
1# exit current shell with2exit3# back in PowerShell now4wsl -d Fedora-33 -u scott5# get user id6id -u7# id -u returns 10008# test that user is on sudoers list9sudo llThat last command will prompt me for the password I created for
scott, presuming that went well then it’s time to set the default
user.
To do that, exit WSL to get back into Powershell.
This PowerShell one-liner configures my user properly, (thanks Jim!)
take note of the last value here 1000 that’s the id -u I checked
for earlier:
1Get-ItemProperty Registry::HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Lxss\*\ DistributionName | Where-Object -Property DistributionName -eq Fedora-33  | Set-ItemProperty -Name DefaultUid -Value 1000The last piece here is to add Copr for the Windows integration:
1# in the Fedora shell2sudo dnf -y copr enable trustywolf/wsluInstall additional packages
Ok, now to get moving with the bits I need for web dev, fist I’ll want to add nano and git:
1sudo dnf -y install nano gitThen for using end to end testing and automation tools like Cypress, Playwright and Puppeteer I’ll first want to install some browsers which will add all the needed libs and packages I’ll need later:
1sudo dnf -y install firefox chromiumInstall Zsh and Oh My Zsh
Zsh has become quite special to me so this is a must for me, if you’re following along then you do you, the majority of the config here can be done with bash too.
1sudo dnf -y install zshThen OMZ with:
1sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"Oh My Zsh will say:
I can’t change your shell automatically because this system does not have chsh. Please manually change your default shell to zsh
I’ll do that next.
Change default shell
There’s no chsh utility in Fedora so if I want to change the default
shell then I’ll need to do this:
1# open the passwd file2sudo nano /etc/passwdLook for something like:
1scott:x:1000:1000::/home/scott:/bin/bashLook for the part with my username, then change the /bash part with
/zsh
Save the changes in nano with Ctrl+o to write out the changes then
Ctrl+x to exit out of nano.
Customise Zsh
I’ve gone over this a couple of times now, if you’re not interested skip along to the next bit.
I’m going to add a few things here, these are essentials for me:
Plugins:
Theme, very important:
Install the plugins first:
1# zsh-syntax-highlighting2git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting3# zsh-autosuggestions4git clone https://github.com/zsh-users/zsh-autosuggestions ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestionsUpdate the plugins array with some added ones from Oh My Zsh:
1plugins=(2  git3  node4  npm5  npx6  nvm7  zsh-syntax-highlighting8  zsh-autosuggestions9)And remember to add the auto suggest config to the .zshrc config
file:
1ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE="fg=#663399,standout"Now for the theme, first up clone and symlink the repo:
1# clone the repo first2git clone https://github.com/denysdovhan/spaceship-prompt.git "$ZSH_CUSTOM/themes/spaceship-prompt" --depth=13# symlink it4ln -s "$ZSH_CUSTOM/themes/spaceship-prompt/spaceship.zsh-theme" "$ZSH_CUSTOM/themes/spaceship.zsh-theme"Then set it to the .zshrc file:
1# nano ~/.zshrc2ZSH_THEME="spaceship"Add starting directory
Add the starting directory to be in the Linux partition.
1# cd to the home directory2~3# mkdir for repos4mkdir repos5# Open the zshrc file6nano ~/.zshrc7# add this at the bottom8cd ~/reposAdd SSH keys
I have one set of SSH keys I keep for my WSL instances, I’ll copy
those to my user home folder with the explorer.exe tool, pop open
the explorer:
1explorer.exe .Paste in my .ssh folder and .gitconfig, one thing to note here is
that sometimes copying files in will set the permissions on the files
to root, check that with:
1# check the .ssh file permissions2ls -lart .ss*3# if it shows root as the owner then change it4-rw-r--r-- 1 root  root   749 Aug 25 17:36 id_rsa.pub5-rw-r--r-- 1 root  root  3389 Aug 25 17:36 id_rsaA really handy way to find the ordinals on a file, (so the numbers
instead of -rw-r--r-- whatever that means) is stat, this command
will give the actual numbers:
1stat -c "%a %n" ~/.ssh/*That gives an output like this:
1644 /home/scott/.ssh/id_rsa2644 /home/scott/.ssh/id_rsa.pub3644 /home/scott/.ssh/known_hostsSo after I change owner I know I’ll need to change the id_rsa to
600 from 644.
In this example the owner is root so I’ll change it to my user
(scott):
1# change ownership of folder and contents2sudo chown scott:users .ssh/ .ssh/* .gitconfigNow to change the permissions on the id_rsa file and authenticate
with GitHub:
1# change to the .ssh/ folder2.ssh/3# set permission4sudo chmod 600 id_rsa5# change out to set the folder permissions6../7sudo chmod 700 .ssh/8# authenticate with GitHub9ssh -T git@github.comInstall nvm
Install nvm for that Node version goodness:
1curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.34.0/install.sh | zsh2source ~/.zshrc3command -v nvm4# sets default to 145nvm install 146# nvm alias default 14Install Yarn
Install Yarn with the instruction for the Yarn docs:
1curl --silent --location https://dl.yarnpkg.com/rpm/yarn.repo | sudo tee /etc/yum.repos.d/yarn.repo2sudo dnf -y install yarnInstall a global yarn package and make sure global binaries are showing.
In this case I’ll add Vercels CLI:
1yarn global add vercelThen try to login with vc login I get a response of:
1zsh: command not found: vercelSo I need to set the prefix:
1# confirm global path2yarn global bin3yarn config get prefix4# When I ran this it was undefined, so I set it:5yarn config set prefix ~/.yarnAdd the following to my ~/.zshrc file:
1export PATH="$PATH:`yarn global bin`"Reload the shell:
1source ~/.zshrcAnd try again:
1vercel loginSet the $DISPLAY variable
Unlike with the Fedora Remix for WSL the display variable needs to be set in Fedora 33, so I’ll go through the same process as I did in my Enable GUIs WSL post. Credit to Nicky Muleman and his post that give me the initial details.
1# set DISPLAY variable to the IP automatically assigned to WSL22export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk '{print $2; exit;}'):0.0Run a project that uses a GUIs
I have an xserver in x410 that’s already running, if you need to set up an xserver check out Nicky’s post on getting it set up.
I’m going to clone MDX Embed as I know it uses Cypress and run the command to do end to end tests with Cypress once it’s finished installing:
1git clone git@github.com:PaulieScanlon/mdx-embed.git2# then install dependencies3yarn4# and run yarn cy:test to test5yarn cy:testReferences and tips
Now that I’ve installed all the things I need I can run:
1sudo dnf clean allThis will clear up all the unused files.
If I want to start over I can use:
1wsl --unregister Fedora-33This will remove the Fedora install so I can start again.
Wrap!
that’s it, I’ve gone and installed an off the shelf version of Linux on my Windows machine and configured it for use in web development.
Back to Top