Visual Studio Code Remote - WSL
The Remote - WSL extension lets you use VS Code on Windows to build Linux applications that run on the Windows Subsystem for Linux (WSL). You get all the productivity of Windows while developing with Linux-based tools, runtimes, and utilities.
Remote - WSL lets you use VS Code in WSL just as you would from Windows.
Why do I need Remote - WSL?
WSL lets you run a Linux environment -- including command-line tools and applications -- directly on Windows, without the overhead of a traditional virtual machine or dualboot setup. WSL especially helps web developers and those working with Bash and Linux-first tools (i.e. Ruby, Python) to use their toolchain on Windows and ensure consistency between development and production environments.
When you install a version of Linux on Windows, you’re getting a full Linux environment. It's isolated from Windows- the UI is the terminal, and you can install tools, languages, and compilers into the Linux environment without modifying or disrupting your Windows installation.
We recommend using WSL 2 as you will benefit from significant performance advantages over WSL 1.
Why Remote – WSL in VS Code?
While you can edit files in Linux using Windows-based tools, you can’t easily run or debug on Windows: you'd have to install all the same tools on Windows as you did on Linux, defeating the purpose of having an isolated Linux environment. You could view files from your
With VS Code and the Remote - WSL extension combined, VS Code’s UI runs on Windows, and all your commands, extensions, and even the terminal, run on Linux. You get the full VS Code experience, including autocomplete and debugging, powered by the tools and compilers installed on Linux.
You can launch a new instance of VS Code connected to WSL by opening a WSL terminal, navigating to the folder of your choice, and typing
To get started with your first app using Remote – WSL, check out the step-by-step WSL tutorial in docs:
The extension adds several commands to VS Code. You can bring them up by pressing
Remote-WSL: New Window
A new VS Code window will open, connected to your default WSL distro.
Notice the green remote indicator updates to the WSL distro to which you are now connected (in this case, Ubuntu). You can select the Open Folder button to view the contents of your remote Linux distro's file system:
When you select a folder, VS Code will set up the environment, and a new VS Code window will appear with the contents of that WSL folder.
When you hover over any of the files within your folder, notice they have the correct Linux paths:
To open a Terminal, you can use the Ctrl+` keyboard shortcut. Notice that when you run “uname,” it shows you’re on a Linux machine:
Remote-WSL: New Window Using Distro...
Like Remote-WSL: New Window, this command opens a new VS Code window connected to WSL. But first, it opens a quick pick so that you can select a specific WSL distro:
Remote-WSL: Reopen Folder in WSL
Reopen a folder in WSL that is currently open in a VS Code instance connected to Windows.
If your folder resides in the WSL file system, hovering over it will display a Linux path. If your folder resides in Windows, you’ll see the mount point that was automatically created by WSL, i.e.
Using an Alpine Linux based distro? Extensions may not work due to
Working with Git? Here are two tips to consider:
As with VS Code itself, the extensions update during a development iteration with changes that are only available in VS Code Insiders Edition.
Questions, Feedback, Contributing
Have a question or feedback?
Or connect with the community...
Visual Studio Code Remote - WSL and related extensions collect telemetry data to help us build a better experience working remotely from VS Code. We only collect data on which commands are executed. We do not collect any information about image names, paths, etc. The extension respects the