DEV Community

Google Cloud

Ministry of Silly Runtimes: Vintage Python on Cloud Run

di profile image Dustin Ingram Updated on ・5 min read

Introducing Cloud Run

Today, Google announced Cloud Run, a product that is really beautiful in its simplicity:

1) You write an service/app/function/whatever that listens for HTTP requests on $PORT;
2) You write a Dockerfile that inherits from any base image, installs any necessary dependencies, and starts your service;
3) You deploy the image to Cloud Run, and it scales on demand (even to zero).

Basically, it's "serverless Docker containers as a service" and it's exactly what I think the PaaS/FaaS development community could use right now, for a number of reasons:

The most idiomatic runtime possible
There's no potential for vendor-specific weirdness here. Really, you can't get more idiomatic than using FROM python:3.7, or whatever other base image you want to use.

Customizability without paying for idle virtual machines
If you have specific workloads that don't fit within the bounds of the most "common" runtimes usually provided, before now your best option was to spin up a custom VM which won't scale to zero and will spend a lot of time sitting idle. With Cloud Run, you can use the Dockerfile to customize your runtime to your heart's content.

Containerization means portability
Defining your runtime with a standard Dockerfile means you can take it anywhere—even locally—which means that you're not locked into a specific vendor, and that local development of your application is built right in without needing to do anything special.

These are all great, and they'll certainly help developers do great things...

...But what if you wanted to do something really silly with it instead?

Introducing the first Python 1.x serverless runtime

When I first started playing with Cloud Run, I really wanted to test the limits of what I could do with it. Could I really run any runtime I wanted? Could I run a super modern Python 3.8.0a3 alpha release? (Yes). Well, what about a "vintage" version of Python? Could I deploy a "Hello World" app running on Python 1.x to Cloud run? 🤔

Searching for "vintage" images

The first problem was finding a base image for Python 1.x. The official Python Docker images only publish images for 2.7 and up, so no luck there. I couldn't find it anywhere else, so it looked like I'd have to build the base image from scratch myself.

Searching for "vintage" source

Building the base image from scratch meant that I had to:

a) Find the old source code for a Python 1.x version;
b) Get it to compile on a modern distribution's base image;
c) Publish this new base image.

Finding the source was slightly challenging. The source for modern Python releases is published on, but this only goes back as far as Python 2.0.1, released June 22, 2001.

Luckily, I found, which includes source releases as far back as Python 1.0.1, which was released just over 25 years ago on February 15th, 1994.

I decided to attempt to target the latest Ubuntu distribution, and amazingly, with just some small patches, I was able to get Python 1.0.1, 1.1, 1.2 and 1.3 to compile under Ubuntu 18.04.

Publishing some "vintage" images

I published these resulting builds as Docker images under the vintage-python repository, so this means you can now start a vintage Python REPL whenever you want:

$ docker run -it dustingram/vintage-python:1.0.1
Python 1.0.1 (Feb 23 2019)
Copyright 1991-1994 Stichting Mathematisch Centrum, Amsterdam
>>> print "Hello world!"
Hello world!

It also means I can do FROM dustingram/vintage-python:1.0.1 in my Dockerfile, which is a huge step towards having my silly runtime.

Searching for an HTTP server

I had my heart set on Python 1.0.1, but after realizing that Python didn't ship with an HTTP server until Python 1.3, I decided to use that instead of attempting to backport the HTTP server to an older version.

In Python 1.3, I was able to write this:

import sys
from BaseHTTPServer import HTTPServer
from SimpleHTTPServer import SimpleHTTPRequestHandler

class MyHandler(SimpleHTTPRequestHandler):
    protocol_version = "HTTP/1.1"

    def do_GET(self):
        self.send_header("Content-type", "text/html")
        self.wfile.write("Hello from Python " + sys.version)

if __name__ == '__main__':
    HTTPServer(('', 8080), MyHandler).serve_forever()

This sets up a basic HTTP/1.1 server on port 8080 that responds to every request with the given message. I really wanted to prove that this was a vintage version of Python serving the request, so I included the sys.version along with the response.

Containerizing some vintage Python

After saving that as, all that was left to do was write the Dockerfile. Since my app doesn't have any dependencies, the Dockerfile is pretty close to the Dockerfile in the Cloud Run quickstart

FROM dustingram/vintage-python:1.3

# Copy local code to the container image.
COPY . .

# Service must listen to $PORT environment variable.
# This default value facilitates local development.

# Run the web service on container startup.
CMD ["python", ""]

Here, we inherit from my vintage Python image, copy in my to the container, set the PORT environment variable (for local development), and then start the server by running python

Deploying some vintage Python

With Cloud Run, there's a two step deploy:

Build and submit your image with Cloud Build:

$ gcloud builds submit --tag

Then, deploy the submitted image to Cloud Run:

$ gcloud beta run deploy --image

And then it was deployed!

See it in action here:


Cloud Run is definitely flexible enough to run any runtime I could throw at it -- even one of the oldest versions of Python. Obviously I wouldn't seriously encourage anyone to use Python 1.x in production: any version past it's EOL is essentially unmaintained and severely feature-limited.

From here, you can:

Discussion (2)

jay97 profile image
Jamal Al

Do they have testing plans or u need to pay before

felipehoffa profile image
Felipe Hoffa • Edited

See the free tier in the pricing section here:

(2 million requests per month, but check the link for details)

Forem Open with the Forem app