Developers should be using docker and compose for their sandbox...

Developers should be using docker and compose for their sandbox...

This might seem obvious to some, but as a longtime VMware engineer, I've always been in the habit of running VMware Workstation on my desktop or Fusion on my Mac laptop. So whenever I was starting a new project, I'd just take a snapshot of my VM and work on a clean image.

An image showing VMWare Workstation snapshot manager with several snapshots off the base image
VMWare Snapshot Manager

I've used Docker a lot for the runtime engine where I run microservices, but I never really got into the habit of running Docker on my desktop, but that's about to change.

With so many new projects around GenAI popping up all the time, along with new libraries, Python packages, cloud services, and more, I wanted something better than the VM approach. Creating a new VM to try a new Python package is inefficient, uses up more memory, so it's hard to run several at one time. So instead, I end up experimenting on my one VM image, which then gets loaded with junk and is no longer pristine.

I sometimes try using Python virtual environments, which are okay, but don't really lend themselves well to packaging an application for deployment, or I forget to enable the environment, or I'm in a different environment and don't realize it. It all adds up to wasted time debugging, troubleshooting, managing, and maintaining.

A colleague (special thanks to Eric Vogelpohl) convinced me to take some time and develop some stacked base containers from which I can build. Since Docker is already a highly layered approach, it's very easy to create a base image for Python, then one for Python and Jupyter Notebooks, or another for Python and a Git repo I want to play with. Each environment is separate and pristine, and using Docker Compose, I can pretty easily manage them. Plus, Docker Desktop is a breeze to work with.

An image of docker desktop app showing a running container and a menu on the left for interacting with containers, images, volumes and more
docker desktop

I then decided to try using external volumes, so any source files can be physically stored on a shared folder and modified outside of the container itself. This way, the container just becomes a pristine runtime environment for me to run all my different projects through.

Here's a simplified example of a base Dockerfile for Python:

FROM python:3
COPY requirements.txt . 
RUN pip install -r requirements.txt  
EXPOSE 8000          

And a simple docker-compose.yaml file to manage it, along with an external file share for the source code

version: '3.7'

services:
  webapp:
    build:
      context: .
      dockerfile: Dockerfile
    working_dir: /myapp
    command: uvicorn main:app --host 0.0.0.0 --port 8000 --reload
    ports:
      - "8000:8000"
    volumes:
      - C:/Users/{USER}/OneDrive/Devel/python/projects/projectX
    environment:
      - OPENAI_API_KEY
      - TAVILY_API_KEY
    deploy:
      resources:
        limits:
          memory: 8G   # Limit memory usage to 8GB
          cpus: "2.0"  # Limit CPU usage to 2 CPUs
        reservations:
          memory: 4G   # Reserve 4GB memory
          cpus: "1.0"  # Reserve 1 CPU
               

Using this approach, I can just copy this as many times as I want, modify the requirements.txt file for each build to keep things pristine, and I always have a lightweight runtime environment to run, test, and develop my apps in.

Happy Coding


Transitioning to containers offers flexibility and efficiency. How have others experienced this shift?

Like
Reply

To view or add a comment, sign in

Insights from the community

Others also viewed

Explore topics