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.
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.
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.
Recommended by LinkedIn
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?