The fully realized browser-based IDE has been a long time coming. Ever since the beginning of the cloud revolution, I’ve thought a powerful and flexible remote IDE was just around the corner. I imagined a development tool that could use any virtual machine as a development platform. 

I think that dream has finally been realized. I recently tried out VSCode.dev, and while there are some rough edges to be worked out, it’s already a pleasure to use.

VS Code is one of the most popular IDEs available. I believe its popularity comes down to the balance of utilitarian simplicity and extensible power. If you need a supercharged Notepad, VS Code has you covered. Or, you can use it as a full-blown platform with debugging and integrations galore.

Most everything a developer needs is available via VS Code extensions. Some areas are a tad more polished—for example, .Net languages like C# tend to work very well right out of the box, whereas Java and other languages require more tinkering. That’s to be expected, given VS Code’s provenance at Microsoft. You’ll also see this in the browser version. But overall, VSCode.dev is a polyglot-friendly, impressively handy software development tool that delights the coding enthusiast.

Using a remote virtual machine with VSCode.dev

With VSCode.dev, attaching to a remote virtual machine (VM) is fairly painless. You just need three pieces in place:

  • A remote VM with the VS Code command-line tool installed and running.
  • A GitHub (or Microsoft) account that you can use to bestow permissions.
  • The VSCode.dev browser client, which uses the CLI and permissions to create a tunnel.

I’m using a Debian compute instance on Google Cloud Platform (GCP) but any type and provider will work. Once the machine is running, SSH into it and install the VS Code CLI. You can download the CLI here. Installation is straightforward; for example, here are the instructions for Linux.

Once you have the VS Code CLI installed, you can start the tunnel server with the following:


$ code tunnel

You’ll see confirmation that it is listening for connections, as shown below.

A screenshot of the VSCode.dev online browser.

To access the tunnel in your browser, you can just use the URL VS Code provides. In my case, it’s https://vscode.dev/tunnel/dev3. Or, you can go to VSCode.dev, as shown here:

A screenshot of the VSCode.dev online browser.

Either way, login to your GitHub account through the Remote Explorer menu on the left side of the above screen. This opens a slider pane where you will click the link Sign in to tunnels registered with GitHub, as shown below.

A screenshot of the VSCode.dev online browser.

You’ll see the following confirmation:


The extension 'Remote - Tunnels' wants to sign in using GitHub.

If you confirm this, it’ll launch a third-party integration, allowing you to log into your GitHub account, where you’ll give permission to VS Code:

A screenshot of the VSCode.dev online browser.

After you’ve done that, continue to the account you want to use:

A screenshot of the VSCode.dev online browser.

Now check the remote explorer beneath REMOTES (TUNNELS/SSH) and Tunnels. You should see your virtual machine listed as “Running” in the list of machines, as shown below:

A screenshot of the VSCode.dev online browser.

In my case, the VM is named “dev3,” and if I click the arrow beside it, I can open it in my current window.

The remote machine view

Now, we are tunneled into the VM and the file browser will let us access the filesystem there. For example, I can open the .NET-HTMX example application from a recent InfoWorld article and use Add folder to workspace to add it to the VSCode.dev IDE:

A screenshot of the VSCode.dev online browser.

That launches the filesystem browser, and you’ll see the remote directories reflected in the combo box, which starts in the default directory and allows you to browse:

A screenshot of the VSCode.dev online browser.

You will be asked if trust the authors—which presumably you do, since the author is you:

A screenshot of the VSCode.dev online browser.

You also have the option to click “no” and open the folder in restricted mode (more info about that here).

Now, if we open the file explorer on the left, we’ll find the remote directory loaded:

A screenshot of the VSCode.dev online browser.

This is the same view we’d have if we were looking at a local installation of VS Code, except we’re browsing remotely. Nice!

Install an extension

Now let’s take a look at adding an extension. This works just like an installed edition of VS Code. Since we are looking at a C# project, let’s add the official C# extension. Open the Extensions menu on the left of the screen shown below and type “C#”.

A screenshot of the VSCode.dev online browser.

The Microsoft C# extension will appear in a drop-down list and you can install it from there.

Now our project will light up with context-sensitive help and the other niceties we expect.

Running the project in dev mode

A unique challenge of remote development is launching a project and then using it from the user perspective while also debugging or making code changes in the remote IDE. Fortunately, VSCode.dev has smoothed out that wrinkle. If you click and open Program.cs in the navigator, you’ll see it’s recognized as an executable. This is indicated by the debug command palette at the top of course screen, including a Run button on the right:

A screenshot of the VSCode.dev online browser.

Clicking Run will initiate another round of permission dialogs. You’ll see one from GitHub:

A screenshot of the VSCode.dev online browser.

And another one from Microsoft:

A screenshot of the VSCode.dev online browser.

Once you’ve accepted those, you’ll be able to visit your running application using the provided URL:

A screenshot of the VSCode.dev online browser.

You can view console output in the Debug tab at the bottom of your screen.

Stop the server

To halt the execution of a running app, use the Command button at the top of your screen:

A screenshot of the VSCode.dev online browser.

The Port tab at the bottom of your screen lists all the running projects and reminds you of what URL goes to what project. You can stop any project from there.

How about some Kotlin?

I’ve been on a Kotlin kick lately, so let’s try something a bit more exotic for VS Code and import a Kotlin project to work on. To import the project, I follow the same basic steps we did for the .NET-HTMX project:

Running the Kotlin project takes a little more finagling to figure out. First, I right-click on the imported build.gradle.kts file. This yields a context menu that includes “Gradle” along with a Run task option. Opening this leads to another context menu where I have the option to run a Gradle task. I type run and the console gives the expected output as the server starts up:

A screenshot of the VSCode.dev online browser.

When I open the port, I can view my application running. After a page refresh, the Gradle extension provides a Gradle tab on the left side of my screen, which exposes tasks like Run in its drop-down menus. Running the Kotlin app involved a couple of additional steps but nothing onerous.

VSCode.dev with GitHub Codespaces

Another approach supported by VSCode.dev is running projects using GitHub Codespaces, a managed cloud hosting environment. Codespaces is a cloud development environment like GitPod. It gives you 60 hours of development time for free and then charges based on the type of VM you are using.

Starting in VSCode.dev, open the Remote Explorer pane on the left of your screen. Select GITHUB CODESPACE and click Create Space:

A screenshot of the VSCode.dev online browser.

After another set of permissions, you’ll get access to your repositories in GitHub, as shown in the above screenshot. I select MTyson/iw-java-spring-react from my repository and then the main branch, and then 2 cores with 8 GB of RAM from the options provided.

This causes a new window to launch with a Codespaces version of VS Code. It offers to install a recommended extension for this repository (Extension pack for Java), which I accept. After that, there is a walkthrough to help configure the environment, beginning with installing a JDK.

Fortunately, Codespaces comes with SDKMan already installed so it’s easy to update the Java version from 11 (which is already installed) to Java 21 (which I used for my Spring-React project). From the terminal, I type:


$ sdk install java 21.0.2-open

Once that is completed, I can run the project with:


$ maven spring-boot:run

Much like running the application in VSCode.dev, the Port tab shows the running application and lets us access the UI. We can also manage the running app from Codespaces. When you are ready to shut down Codespaces, head back to the main VSCode.dev page and use the Remote Explorer menu.

Container-based development has some differences from tunneling to the VM, particularly around the lifecycle of the image and its containerized nature. Otherwise, the development experience is similar.

Conclusion

VSCode.dev opens up some new possibilities specific to a browser-based IDE. Beyond the flexibility of being able to code from anywhere, VSCode.dev can turn any cloud machine into a development platform, and give you full-blown IDE interaction with your projects on the cloud. It also supports multiple developers using the same environment for a collaborative social coding experience.

Overall, VSCode.dev is a great addition to your development toolkit.