July 3rd, 2024

Developing Inside a Container

The Visual Studio Code Dev Containers extension allows developers to create a development environment within a container, ensuring consistent tool access and runtime stacks. Users need Docker installed and can enhance functionalities with extensions like Remote Development.

Read original articleLink Icon
Developing Inside a Container

The Visual Studio Code Dev Containers extension enables developers to work within a container as a comprehensive development environment. By utilizing a devcontainer.json file in the project, Visual Studio Code can access or create a development container with a predefined tool and runtime stack. This container allows running applications or isolating tools, libraries, and runtimes necessary for working with a codebase. Workspace files are mounted or copied into the container, and extensions run inside it, providing full access to tools and the file system. This setup enables seamless switching of the development environment by connecting to a different container, ensuring a consistent development experience with features like IntelliSense, code navigation, and debugging. The extension supports using a container as a primary development environment or attaching to a running container for inspection. It adheres to the open Dev Containers Specification, allowing configuration of a consistent development environment across different tools. To get started, users need to have Docker installed locally or on a remote host, meeting specific system requirements outlined for different operating systems and container environments. Extensions like Remote Development can be installed for additional functionalities.

Link Icon 24 comments
By @lewantmontreal - 6 months
Don’t fall for this. It’s too good and I can’t get out now since nothing else than vscode supports it.

Dependencies, env vars, dev databases, ports, everything all written up in code and ready to use once you open the workspace. All without messing up your host pc. Works also via ssh.

By @Yanael - 6 months
I started to develop in containers before VSCode introduced the dev container to keep my local machine clean. A few years ago, I switched to the VSCode dev container, and the integration is very good. Having the ability to have a dev environment ready per project is very neat. We started to adopt it in my company. As a team it saves a lot of hassle, and onboarding is much faster. However, we have encountered some issues, mainly when we want to work with GPU and PyTorch dependencies, and that is the opposite of pleasant! Otherwise, now each new project/repo I create comes with a dev container.
By @btbuildem - 6 months
I'm not sure I follow -- do they suggest running VS locally, and the work/project inside the container?

I've been doing this for years, it seems to me like the absolutely hands-down easiest way to keep projects encapsulated and easily shareable with coworkers.

Set up the env in a docker container, mount a volume to a local fs where all the sources live, ssh into the container if necessary, interact with app(s) within the container over http.

What's MS adding here, what am I missing? They streamline the process and integrate scripts with VS?

By @christophilus - 6 months
I’ve been developing inside of Podman containers using Neovim. It’s mostly great. I love that my machine doesn’t get cluttered with random dev dependencies.

Yesterday, though, I ran into an issue where Bun was occasionally not completing http requests. I thought it was a bug with Bun (it might be), but the issue went away when I ran it outside of a container.

Containers do add layers which sometimes cause issues, or at least make diagnosis trickier.

By @gabrielteixeira - 6 months
I recently started using this workflow and I'm very pleased by it.

Now, for every project I start, I quickly create a Docker container with all dependencies the project needs, and then I develop inside the container using vscode. If I need to develop in another machine (laptop instead of my desktop for example), I just download the Docker image, and everything is already setup to start coding.

By @cogman10 - 6 months
We've been using tilt [1] for a similar process.

If you are doing a k8s deployment anyways then tilt is really quiet nice once properly setup.

The one thing that isn't so nice is local package caching. That's a hard problem to solve and containers makes it annoying to get right.

[1] https://tilt.dev/

By @darkxanthos - 6 months
We've been using this where I work for over a year and I'm never going back.
By @cjr - 6 months
https://devspace.sh also gives a similar workflow but where the container is running in a remote k8s cluster
By @mikedelago - 6 months
I like tilt [https://tilt.dev] if the dev infra has any significant complexity to it.

Docker compose also has a "watch" command that can do lots of the the things devcontainers does, and I use it for more simple setups.

https://docs.docker.com/compose/file-watch/

By @emmanueloga_ - 6 months
I guess I've been living in SF for too long... upon seeing the headline, my first thought was "a developer working from his container home, makes sense".

DevContainers are good. I find them especially nice for working on k8s stuff. For those comparing them against Nix, it's likely that most developers are already familiar with Docker, while Nix's language and tools have a pretty steep learning curve.

By @ErneX - 6 months
I’ve been using DevPod (https://devpod.sh) for this and it’s been pretty great.
By @Neywiny - 6 months
I like this but I use an x86 32-bit box for my "home lab" (for the fun of needing to compile everything myself) and it'd be nice if VSCode supported that natively. As is I had to compile VSCode server myself, which isn't exactly what I wanted. Unsure if I can even add 32-bit x86 to this functionality.
By @Goofy_Coyote - 6 months
My biggest problem with DevContainers has been getting the debugger to work. I need to walk through the code for my job, and it’s been a pain to get it to work in a container. Never understood what I’m doing wrong though, theoretically it shouldn’t be any different than how I set it up on my local machine.
By @ronef - 6 months
While I personally don't love developing at all times within a container. When I need to, I've found the flow of setting up with Nix and then containerizing to be the most ideal today. Is there something new recently that folks are using?

(I'm also a biased person as I'm a Nix person at heart)

By @humanfromearth9 - 6 months
Somehow I still prefer using Nix to have consistent dev env...

Does the container approach bring something more than using Nix?

By @throw156754228 - 6 months
Isn't this just glorified bind mount? I skimmed the article but could not see what this does other than let you write files in your docker container through VS code. Why not just set up a bind mount and run any old editor?
By @spaniard89277 - 6 months
Mmm, I already do this with LXC, but could be better integrated, I guess?

My next goal was to use Docker for this, but since I don't know docker yet, I'm not sure if that would a good idea for having a ready prod env right after a commit.

By @janpmz - 6 months
I like the concept. What I didn't like was:

- Re-opening the project in a dev container felt like overhead

- I sometimes stuggled with setting the work directory

- Restarting the development container for various reasons interrupts the development

By @remlov - 6 months
I fail to see how this is any better than IntelliJ/PyCharms remote interpreter feature and Services tab and a proper docker-compose file. It feels like VSCode is finally catching up.
By @humanfromearth9 - 6 months
Somehow I still prefer using Nix to have consistent dev env...

Does the container approach bring something more than using Nix?

By @jFriedensreich - 6 months
i much prefer using docker “compose watch”, i never fully managed to wrap my head around the relationship and proper setup of vscode workspace, project and container.
By @topaztee - 6 months
is this like rookout?
By @taspeotis - 6 months
This feature is at least 5 years old, why isn't (2019) in the title?

https://github.com/microsoft/vscode-docs/blob/3bafb9f610bd6b...

Hacker Olds, amirite.