Skip to content

Latest commit

 

History

History
295 lines (189 loc) · 9.25 KB

wsl_cheatsheet.md

File metadata and controls

295 lines (189 loc) · 9.25 KB

Hello and welcome to this WSL2 Cheatsheet.

The goal is to gather here all tips and known issues about WSL2!

Issues

Input/Output error

This happens when the hidden wslhost.exe is not working. We just need to restart it!

Close all WSL2 tabs.

Open a PowerShell tab and run the following command:

wsl.exe --shutdown

Check that your Ubuntu is properly stopped with the command

wsl -l -v

Open a new WSL2 Tab, problem should be fixed.

ERR_CONNECTION_REFUSED / Unable to reach localhost

If you get this error trying to connect to your rails server, serve or jupyter notebook, a simple restart of WSL might do the trick.

  • Open a new PowerShell tab
  • Run wsl --shutdown to shutdown WSL.
  • Open a new PowerShell tab or run wsl to restart WSL.
  • Retry to connect to localhost:xxxx. You can as well try 127.0.0.1:xxxx (the local IP of the machine) instead.

If the issue is still present, you need to allow the connection in Windows Defender Public rules. Close all WSL terminal. Open a PowerShell terminal and type the following command to stop all WSL processes:

wsl --shutdown Ubuntu

Hit Start and type Windows Defender Firewall and open it.

Click on Advanced Settings

Right click on Inboud Rules and select New Rule.... Under Rule Type leave Program selected and hit Next.

For the program, Select The program path: and paste this path: %SystemRoot%\System32\wsl.exe. Click on Next.

For the Action section, make sure Allow the connection is selected and hit Next.

For the Profile section, make sure the 3 options are selected and click on Next.

Finally you will be asked to chose a name for this new rule, go with WSL - Inbound.

Repeat the whole process by creating a Outbound Rule with the same settings, except for the name: WSL - Outbound.

Insecure World Writable

The warning Insecure world writable dir /mnt/c in PATH, mode 040777 is caused by the two differents way of Windows & Linux to deal with file permissions. To silence those warnings:

sudo touch /etc/wsl.conf
echo '[automount]' | sudo tee -a /etc/wsl.conf > /dev/null
echo 'options="metadata,umask=0033"' | sudo tee -a /etc/wsl.conf > /dev/null

Restart all terminals.

Update version 2004 not offered

Microsoft is slowly releasing the latest major version of Windows (version 2004). Here is the guideline if your Windows is not offering you the update. Go to Windows 10 and under Windows 10 May 2020 Update click on Update now. This will download a tool on your machine. Open it.

A compatibility check will start:

windows_2004.png

Next, you will be offered a choice, choose Upgrade this PC now and click on Next:

windows_2004.png

Let the tool do the work:

windows_2004.png

Microsoft is encountering some errors with the version 2004, Chances are that the update assistant will tell you that you're machine is not compatible yet! Do not close the assistant. Open a file explorer at this path C:\$WINDOWS.~BT\Sources\Panther Locate the file compatscancache.dat and delete it Go back to the update assistant and click Refresh.

The installation should carry on.

Sudo apt update connection timed out

This happens if you're using AVG antivirus. Disable AVG VPN if you're using it.

Open AVG Internet Security -> Menu - Settings - Full Protection - Enhanced firewall. Check Enable Internet connection sharing mode On the same page, click on System Rules and enabled the first 2 options Windows file & printer sharing Remote desktop connections Scroll down to click on save.

Slow network

If you experience slow network on your fresh WSL2:

  • Open Ubuntu (or your other distro)

  • Open Network Connections in your settings ("View network connections" in your windows search)

  • You should see

  vEthernet (WSL)
  Enabled
  Hyper-V Virtual Ethernet Adapter
  • Right-click and open Properties

  • In the Properties pane, click Configure...

  • In the Configure pane, go to the "Advanced" Tab

  • Click on "Large Send Offload Version 2" and update the value to "Disabled"

If you see two "Large Send Offload Version" options, disable both.

Cloudinary: Stale request

If you see issues connecting to your Cloudinary API from your local WSL and you saw this error.

Stale request - reported time is 2016-12-15 04:14:53 +0000 which is more than 1 hour ago

The error is caused by a different system time between the WSL OS and the windows host machine. To fix it, please run this command in your windows terminal:

sudo hwclock -s

Type your WSL password and click enter.

Tips

Check Windows Subsystem for Linux

Open a PowerShell terminal.

Type the following command:

wsl -l -v

It will tell you the name of your WSL, it's state and version.

Switch from version 1 to version 2

To switch a WSL from version 1 to 2, open a PowerShell terminal.

Type the following command: ⚠️ The conversion's time depends on the size of your Ubuntu filesystem, it can be long and WSL will be unsuable in the meantime. ⚠️

wsl --set-version Ubuntu 2

You can revert to version 1:

wsl --set-version Ubuntu 1

Access root session

To access the root session, open a PowerShell terminal.

Type the following command:

wsl -d Ubuntu -u root

You can change the password of that root session by using the command:

passwd

You will prompted to enter a new password.

Now, from your normal session, you can switch from your session to the root on with:

su -

You will be asked for the password.

You can exit the root session with Ctrl + D.

Testing on Rails

Testing wont work by default on WSL2. It requires ChromeDriver and Chrome binary installed. For this we will need the root session ( AKA The super-mega-admin-session ).

You may skip the reset of the password if you already have one for your root session.

Close all WSL2 tabs. Open a PowerShell tab and run the following command:

wsl -d Ubuntu -u root

You are now login in your Ubuntu as root.

Type the following command to change it's password:

passwd

You will be prompted twice for a new password.

Close this WSL2 tab.

Open a WSL2 tab, you should be logged in with your account. Run the following command (line per line):

sudo apt-get update
sudo apt-get install -y unzip xvfb libxi6 libgconf-2-4

We need to act as the root session for the next command, so let's login as root (you will be prompted for the root password):

su -

Now, let's run:

sudo curl -sS -o - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add
sudo echo "deb [arch=amd64]  http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list

Press Ctrl+D to quit the root session.

If you are unsure about which session you're logged in with, you can use the whoami command 💡.

Let's run the following commands to install Google Chrome binary and ChromeDriver on your WSL2:

sudo apt-get -y update
sudo apt-get -y install google-chrome-stable
wget https://chromedriver.storage.googleapis.com/2.41/chromedriver_linux64.zip
unzip chromedriver_linux64.zip
sudo mv chromedriver /usr/bin/chromedriver
sudo chown your-session-here:your-session-here /usr/bin/chromedriver
sudo chmod +x /usr/bin/chromedriver

⚠️ Replace your-session-here by the result of the command whoami. My result is barangerbenjamin:barangerbenjamin. ⚠️

You can now use testing in Rails. You need to open a second tab and run:

chromedriver

In the other tab you can run your tests with:

rails test:system