- Frequently Asked Questions about Windows Subsystem for Linux
- What is Windows Subsystem for Linux (WSL)?
- Who is WSL for?
- What can I do with WSL?
- Could you describe a typical development workflow that incorporates WSL?
- What is Bash?
- How does this work?
- Why would I use WSL rather than Linux in a VM?
- Why would I use, for example, Ruby on Linux instead of on Windows?
- What does this mean for PowerShell?
- Can I run ALL Linux apps in WSL?
- What Windows SKUs is WSL included in?
- What processors does WSL support?
- How do I access my C: drive?
- How do I set up Git Credential Manager? (How do I use my Windows Git permissions in WSL?)
- How do I use a Windows file with a Linux app?
- Are files in the Linux drive different from the mounted Windows drive?
- Why are there so many errors when I run apt-get upgrade?
- How do I uninstall a WSL Distribution?
- Why does ping generate permission denied errors?
- Why do I get «Error: 0x80040154» when I run bash.exe after upgrading Windows?
- How do I change the display language of WSL?
- Why do I not have internet access from WSL?
- How do I access a port from WSL in Windows?
- How can I back up my WSL distros, or move them from one drive to another?
- Where can I provide feedback?
- Удаление WSL после установки Ubuntu из магазина Windows
- audministrator
- Windows 10 – WSL Linux sub system upgrade & remove Legacy version
Frequently Asked Questions about Windows Subsystem for Linux
What is Windows Subsystem for Linux (WSL)?
The Windows Subsystem for Linux (WSL) is a feature of Windows 10 that enables you to run native Linux command-line tools directly on Windows, alongside your traditional Windows desktop and apps.
See the about page for more details.
Who is WSL for?
This is primarily a tool for developers, especially web developers, those working on open source projects, or deploying to Linux server environments. WSL is for anyone who likes using Bash, common Linux tools ( sed , awk , etc.) and Linux-first frameworks (Ruby, Python, etc.) but also enjoys using Windows productivity tools
What can I do with WSL?
WSL enables you to run Linux in a Bash shell with your choice of distribution (Ubuntu, Debian, OpenSUSE, Kali, Alpine, etc). Using Bash, you can run command-line Linux tools and apps. For example, type lsb_release -a and hit enter; you’ll see details of the Linux distro currently running:
You can also access your local machine’s file system from within the Linux Bash shell – you’ll find your local drives mounted under the /mnt folder. For example, your C: drive is mounted under /mnt/c :
Could you describe a typical development workflow that incorporates WSL?
WSL targets a developer audience with the intent to be used as part of an inner development loop. Let’s say that Sam is creating a CI/CD pipeline (Continuous Integration & Continuous Delivery) and wants to test it first on a local machine (laptop) before deploying it to the cloud. Sam can enable WSL (& WSL 2 to improve speed and performance), and then use a genuine Linux Ubuntu instance locally (on the laptop) with whatever Bash commands and tools they prefer. Once the development pipeline is verified locally, Sam can then push that CI/CD pipeline up to the cloud (ie Azure) by making it into a Docker container and pushing the container to a cloud instance where it runs on a production-ready Ubuntu VM.
What is Bash?
Bash is a popular text-based shell and command-language. It is the default shell included within Ubuntu and other Linux distros, and in macOS. Users type commands into a shell to execute scripts and/or run commands and tools to accomplish many tasks.
How does this work?
Check out our blog where we go into detail about the underlying technology.
Why would I use WSL rather than Linux in a VM?
WSL requires fewer resources (CPU, memory, and storage) than a full virtual machine. WSL also allows you to run Linux command-line tools and apps alongside your Windows command-line, desktop and store apps, and to access your Windows files from within Linux. This enables you to use Windows apps and Linux command-line tools on the same set of files if you wish.
Why would I use, for example, Ruby on Linux instead of on Windows?
Some cross-platform tools were built assuming that the environment in which they run behaves like Linux. For example, some tools assume that they are able to access very long file paths or that specific files/folders exist. This often causes problems on Windows which often behaves differently from Linux.
Many languages like Ruby and node are often ported to, and run great, on Windows. However, not all of the Ruby Gem or node/NPM library owners port their libraries to support Windows, and many have Linux-specific dependencies. This can often result in systems built using such tools and libraries suffering from build and sometimes runtime errors or unwanted behaviors on Windows.
These are just some of issues that caused many people to ask Microsoft to improve Windows’ command-line tools and what drove us to partner with Canonical to enable native Bash and Linux command-line tools to run on Windows.
What does this mean for PowerShell?
While working with OSS projects, there are numerous scenarios where it’s immensely useful to drop into Bash from a PowerShell prompt. Bash support is complementary and strengthens the value of the command-line on Windows, allowing PowerShell and the PowerShell community to leverage other popular technologies.
Can I run ALL Linux apps in WSL?
No! WSL is a tool aimed at enabling users who need them to run Bash and core Linux command-line tools on Windows.
WSL does not yet support GUI desktops or applications (e.g. Gnome, KDE, etc.) Follow the Command Line Blog for updates.
Also, even though you will be able to run many popular server applications (e.g. Redis), we do not recommend WSL for hosting production services – Microsoft offers a variety of solutions for running production Linux workloads in Azure, Hyper-V, and Docker.
What Windows SKUs is WSL included in?
Windows Subsystem for Linux is available on the desktop version of Windows for Windows 10 Anniversary and Creators update or later.
Beginning in the Fall Creators update WSL will be available on both the desktop and server SKUs of Windows.
What processors does WSL support?
WSL supports x64 and ARM CPUs.
How do I access my C: drive?
Mount points for hard drives on the local machine are automatically created and provide easy access to the Windows file system.
/mnt/ /
Example usage would be cd /mnt/c to access c:\
How do I set up Git Credential Manager? (How do I use my Windows Git permissions in WSL?)
Git Credential Manager enables you to authenticate a remote Git server, even if you have a complex authentication pattern like Azure Active Directory or two-factor authentication. Git Credential Manager integrates into the authentication flow for services like GitHub and, once you’re authenticated to your hosting provider, requests a new authentication token. It then stores the token securely in the Windows Credential Manager. After the first time, you can use git to talk to your hosting provider without needing to re-authenticate. It will just access the token in the Windows Credential Manager.
To set up Git Credential Manager for use with a WSL distribution, open your distribution and enter this command:
Now any git operation you perform within your WSL distribution will use the credential manager. If you already have credentials cached for a host, it will access them from the credential manager. If not, you’ll receive a dialog response requesting your credentials, even if you’re in a Linux console.
How do I use a Windows file with a Linux app?
One of the benefits of WSL is being able to access your files via both Windows and Linux apps or tools.
WSL mounts your machine’s fixed drives under the /mnt/ folder in your Linux distros. For example, your C: drive is mounted under /mnt/c/
Using your mounted drives, you can edit code in, for example, C:\dev\myproj\ using Visual Studio / or VS Code, and build/test that code in Linux by accessing the same files via /mnt/c/dev/myproj .
IMPORTANT NOTE: One of the key limitations of using WSL is that directly accessing/changing files in your Linux distros’ file system using Windows apps or tools is not supported. See: Do not change Linux files using Windows apps and tools
Are files in the Linux drive different from the mounted Windows drive?
Files under the Linux root (i.e. / ) are controlled by WSL which mimics Linux specific behavior, including but not limited to:
- Files which contain invalid Windows filename characters
- Symlinks created for non-admin users
- Changing file attributes through chmod and chown
- File/folder case sensitivity
Files in mounted drives are controlled by Windows and have the following behaviors:
- Support case sensitivity
- All permissions are set to best reflect the Windows permissions
Why are there so many errors when I run apt-get upgrade?
Some packages use features that we haven’t implemented yet. udev , for example, isn’t supported yet and causes several apt-get upgrade errors.
To fix issues related to udev , follow the following steps:
Write the following to /usr/sbin/policy-rc.d and save your changes.
Add execute permissions to /usr/sbin/policy-rc.d
Run the following commands
How do I uninstall a WSL Distribution?
On builds prior to 1709 (16299) open a command prompt and run:
WSL distributions installed from the store can be uninstalled like any other Windows app, by right-clicking on the app tile and clicking Uninstall, or via PowerShell using the Remove-AppxPackage cmdlet).
Why does ping generate permission denied errors?
In WSL builds Properties -> Uncheck «Use legacy console»
Why do I get «Error: 0x80040154» when I run bash.exe after upgrading Windows?
The «Windows Subsystem for Linux» feature may be disabled during a Windows update. If this happens the Windows feature must be re-enabled. Instructions for enabling the «Windows Subsystem for Linux» feature can be found in the Installation Guide.
How do I change the display language of WSL?
WSL install will try to automatically change the Ubuntu locale to match the locale of your Windows install. If you do not want this behavior you can run this command to change the Ubuntu locale after install completes. You will have to relaunch bash.exe for this change to take effect.
The below example changes to locale to en-US:
Why do I not have internet access from WSL?
Some users have reported issues with specific firewall applications blocking internet access in WSL. The firewalls reported are:
- Kaspersky
- AVG
- Avast
- Symantec Endpoint Protection
- F-Secure
In some cases turning off the firewall allows for access. In some cases simply having the firewall installed looks to block access.
How do I access a port from WSL in Windows?
WSL shares the IP address of Windows, as it is running on Windows. As such you can access any ports on localhost e.g. if you had web content on port 1234 you could https://localhost:1234 into your Windows browser.
How can I back up my WSL distros, or move them from one drive to another?
The best way to backup or move your distros is via the export/import commands available in Windows Version 1809 and later. You can export your entire distribution to a tarball using the wsl —export command. You can then import this distro back into WSL using the wsl —import command, which can name a new drive location for the import, allowing you to backup and save states of (or move) your WSL distributions.
Please note that traditional backup services that backup files in your AppData folders (like Windows Backup) will not corrupt your Linux files.
Where can I provide feedback?
You can share feedback and ask questions through multiple channels.
If you have technical issues, or want to request new features please go to our Github issue tracker:
If you’d like to stay up to date with the latest WSL news you can do so with:
- Our command-line team blog
- Twitter. Please follow @craigaloewen on Twitter to learn of news, updates, etc.
Удаление WSL после установки Ubuntu из магазина Windows
Я установил WSL, когда он еще был в бета-версии, в 2016 году. Несколько дней назад я также установил Ubuntu из магазина Windows, который имеет более свежую версию (18.04) и отличные цвета текста (и я предполагаю другие улучшения в рамках капот).
Я хотел бы удалить WSL, так как мне не нужны две оболочки Linux на моей машине. Можно ли это сделать? Если так, как бы я это сделал? Я скопировал все, что мне нужно, из моих каталогов WSL в новую подсистему.
Этот ответ не относится к Windows 10 версии 1709+ . Если вы работаете 1709, 1803 или 1809, то вы хотите это . Если вы работаете в Windows 10 версии 1903+, вам нужен этот ответ.
Я хотел бы удалить WSL, так как мне не нужны две оболочки Linux на моей машине. Можно ли это сделать? Если так, как бы я это сделал?
Вы просто запускаете следующую команду в командной строке PowerShell с повышенными правами.
Если вы обновитесь до Windows 10 Fall Creators Update с более ранней версии Windows 10, на которой вы установили WSL, ваш существующий дистрибутив останется без изменений. Однако мы настоятельно рекомендуем вам установить новый поставляемый из магазина дистрибутив как можно скорее и перенести все необходимые файлы, данные и т. Д. Из вашего старого дистрибутива в ваш новый дистрибутив. Чтобы удалить устаревший дистрибутив с вашего компьютера, запустите следующую команду из экземпляра командной строки или PowerShell.
Вы также можете удалить устаревший экземпляр вручную, выполнив следующую команду в командной строке PowerShell с повышенными привилегиями.
audministrator
Windows 10 – WSL Linux sub system upgrade & remove Legacy version
To remove the Ubuntu legacy version of WSL, installing Ubuntu 18.04 and next Upgrading to Ubuntu 20.04 !!
Including upgrading from PowerShell Core 6.1 preview to PowerShell Core 7.0
The short and fastest way is to remove the old version by running this command using Admin privileges :
And next download the appropriate version you want from the MS Store
You can find all steps here to migrate from the original Legacy version to the embedded Windows 10 Version of WSL
This is the long story
Version Check
1. First find out which is the WSL command line options :
You can use this DOS Command to check the installed versions :
I have 2 versions installed on my machine.
And now I will check the UBUNTU Version as well as the PowerShell Core Version
Remove LEGACY WSL Version
Now we can check again an all versions have been removed
Install WSL
So we need to manually install the latest version
Make sure you have the Sub System Feature enabled
See here on which version of UBUNTU to choose
If you install version 16 and want to upgrade to 18 you can run this command in WSL
I go for the later version 1804 at this moment.
Or you can download it from the MS Store too
Next you run this PS command
Initialize WSL
Next you need to initialize the WSL
Go to the Start Menu and select the version you installed to start the ini
fill an account name and password for later reuse.
Check the installed version again
All looks fine again !
Upgrade to latest updates
Run this Linux command :
PowerShell Core
Next install PowerShell Core Version 7 again
All is working fine
for PowerShell Version 6 see here :
Upgrade from 18.04 to 20.4
We don’t need to make any changes since we are upgrading to LTS
If you encounter errors during the upgrade like this :
See here how to solve them :
Check Ubuntu version and PowerShell version again
All looks perfect again now after the Upgrade to Ubuntu 20.04 LTS