Virtualenv Shell Tools? (Development environment isolation)

Soldato
Joined
18 Oct 2002
Posts
6,817
Location
Cambridge
I'm taking on a bit of contract development work, and as part of it I'm going to need to install a toolchain including things like the AWS CLI tool, a particular version of Ruby, NodeJS, kubectl and probably other things I don't know about yet. I have a Mac desktop I'd like to use for this work, but in the past I've always been fastidious about isolating different project dev environments, mainly due to having had horrible experiences with conflicts between different versions of tools :eek:

The last time I was contracting I usually did a combination of the following:

1. Spin up a project-dedicated Linux VM locally or on EC2 / DigitalOcean / Linode
2. Run Docker containers / compose stacks locally
3. Use a dedicated computer just for the project and run everything natively (though this was only really practical for big, long-running projects)

As this work is part-time and I'm not sure how long it'll last, I'm unwilling to do item 3, but having worked with Python recently I was wondering whether there was a lighter-weight way of doing this that doesn't rely on VMs which I could just run on my Mac, similar to Virtualenv? My vision is that all my project tools are only available (and 'loaded') when I'm within a particular project folder on my Mac. I don't mind activating this environment manually if needed.

I'm pretty sure I've come across tools like this in the past, with BSD jails and also running Docker natively on Linux, but I've always found Docker to be really slow and resource-heavy on MacOS, so I'd probably prefer to avoid that this time. I've played with Nix flakes recently, and I suspect these will do just what I want, but unfortunately I find Nix to be a really opaque system which seems to be fragmented by so many opinions that I suspect I'd spend more time tinkering with it than doing actual work! :)

I'd really welcome any thoughts on this from Linux / BSD-based developers. I'm sure in 2024 (nearly 2025!) there must be some good tooling around for this. Thanks :)

EDIT - I am currently investigating Devbox (https://www.jetify.com/devbox/), which seems quite promising.
 
Last edited:
BSD Jails, LXC, Podman Docker are probably some of the better options.

From what you've mentioned, for AWS, Ruby, Node et al I would probably set up an Alpine Container which you can setup for these, some languages have 'equivalent' of pyenv too.

Tip for MacOS, I find Podman works much better than Docker nowadays. I'll be honest, I've moved away from running anything locally nowadays - I have a Mac, but seldom use it and use Debian and/or OpenBSD for the majority of my day-to-day, so I bought a little n100 mini pc for £130ish on sale, and you can run a custom OS on there, whether it's using something more user-friendly like proxmox, running vanilla kvm, just running lxc containers or as a docker target, or OpenBSD and vmd/vmm it doesn't really matter, but it's saved me a lot of time from faffing around, yes I have the CPU and Memory for things locally, but I am slightly old-school and like to keep my computer separate. I run ansible for pretty much all of the automation these days.

*Not a full-time dev, primarily work in Virtualisation/Platform/Automation stuff.
 
Thanks, those are some good thoughts. Docker Desktop seems like a fairly unpleasant piece of software these days, so I'll have a look at Podman.

I tend to prefer developing in Linux environments over the weirdness that is Mac OS, personally, as pretty much all deployments I've encountered in the last 12 years or so have some variant of Linux.

One slight awkwardness with things right now is that there seems to be a bit of a shift away from x86 to ARM for a lot of smaller / clustered workloads I've worked with, but other than the Raspberry Pi and the Apple ecosystem I'm not entirely sure what non-laptop (e.g. workstation) options there are available for this architecture.

If anyone's interested, I'll post an update with what I end up doing, as I think the work will be starting next week :)
 
One slight awkwardness with things right now is that there seems to be a bit of a shift away from x86 to ARM for a lot of smaller / clustered workloads I've worked with, but other than the Raspberry Pi and the Apple ecosystem I'm not entirely sure what non-laptop (e.g. workstation) options there are available for this architecture.

I'm still firmly in the x86 architecture for my industry, but I agree there's not as many options in the 'workstation' variety - but a lot of SBCs more powerful than the Pi, the difficulty they have breaking in to the market is that the Pi is so dominant in it's support, compatibility etc - but they're getting more and more powerful nowadays. I have a Pi 5 8GB and it can run a surprising amount of workload too. I'll be honest, I tend to still emulate arm architecture via qemu.
 
Yeah, I think that for lighter stuff a Pi would be fine, it's just I know from experience that some of the heavy build processes / running certain workloads in debug mode (full logging / tracing etc.) can really hammer even modern systems, particularly in regards to RAM. I was working on a medium-sized project a while ago and was regularly exceeding 24GB RAM use for the few services running locally (on ARM).

If I had a fairly good guarantee of steady work, I think my favourite solution of the past few projects was running a fairly beefy cloud VPS and just remoting into it with Mosh all the time. The main benefit I found was that the process of downloading and installing packages - something I was doing all the time as a NodeJS developer - was so much faster on a server in a datacentre, compared to over my FTTC connection at home or in the office.
 
Back
Top Bottom