Giter Club home page Giter Club logo

docker-python-waitress's Introduction

Python Waitress Docker Container

A Docker container to run a WSGI Python application using Waitress. Images support python 3.6+ and are based on the official python containers. The -slim versions are based on the similarly named python versions.

Pull from Docker Hub

View on GitHub

How to use

  • You don't need to clone the GitHub repo. You can use this image as a base image for other images, using this in your Dockerfile:
FROM tecktron/python-waitress:latest

COPY ./ /app

It will expect a file at /app/app/wsgi.py.

Or otherwise a file at /app/wsgi.py.

And will expect it to contain a variable application with your "WSGI" application.

Then you can build your image from the directory that has your Dockerfile, e.g:

docker build -t myimage ./

Options

All options can be set using environment variables. These can be passed either in a wrapper dockerfile, passing in a .env file or passing them with the -e flag to the docker call.

Prestart Script

If you need to run any startup commands before Waitress runs (an example might be running migrations) you can override the prestart.sh script. This script should live within the /app directory in the container. The image will automatically detect and run it before starting Waitress.

Variables

MODULE_NAME

The Python "module" (file) to be imported by Waitress, this module would contain the actual application in a variable.

By default:

  • app.wsgi if there's a file /app/app/wsgi.py or
  • wsgi if there's a file /app/wsgi.py

For example, if your main file was at /app/custom_app/custom_script.py, you could set it like:

docker run -d -p 80:80 -e MODULE_NAME="custom_app.custom_script" myimage

VARIABLE_NAME

The variable inside of the Python module that contains the WSGI application.

By default:

  • application

For example, if your main Python file has something like:

from flask import Flask
api = Flask(__name__)

@api.route("/")
def hello():
    return "Hello World from Flask"

In this case api would be the variable with the "WSGI application". You could set it like:

docker run -d -p 80:80 -e VARIABLE_NAME="api" myimage

APP_MODULE

The string with the Python module and the variable name passed to Waitress.

By default, set based on the variables MODULE_NAME and VARIABLE_NAME:

  • app.wsgi:application or
  • wsgi:application

You can set it like:

docker run -d -p 80:80 -e APP_MODULE="custom_app.custom_script:api" myimage

Waitress Options

Host & Port Setup

By default, Waitress has been setup to server on all hostnames on port 80 using both IPv4 and IPv6. This translates to --listen=*:80. This works for most applications using the basic setups listed above.

You may have different needs so you can adjust and manipulate this by passing in environment variable to adjust the settings.

WAITRESS_LISTEN

Pass a comma separated list of host:port (EG: host:post,host:port,host:port) to the WAITRESS_LISTEN param

To set Waitress to use port 8080, sent the WAITRESS_LISTEN param like

docker run -d -p 80:8080 -e WAITRESS_LISTEN=*:8080 myimage
WAITRESS_HOST / WAITRESS_PORT

Pass the host and port separately as WAITRESS_HOST and/or WAITRESS_PORT. If port is left out, it will default to 80.

If you want only IPv4, you could use advanced param listed in the section below, but you could also use

docker run -d -p 80:8080 -e WAITRESS_HOST=0.0.0.0 -e WAITRESS_PORT=8080 myimage

Note: The WAITRESS_LISTEN param takes precedence over WAITRESS_HOST & WAITRESS_PORT options, meaning if you include all 3, WAITRESS_HOST & WAITRESS_PORT will be ignored.

Advanced Options

Many of the options that can be passed to waitress-serve are supported by passing in environment variables. These params are only included in the waitress-serve call if they are present in the environment. The supported options are:

Environment Variable Waitress Param
WAITRESS_EXPOSE_TRACEBACKS --expose-tracebacks
WAITRESS_NO_EXPOSE_TRACEBACKS --no-expose-tracebacks
WAITRESS_NO_IPV6 --no-ipv6
WAITRESS_NO_IPV4 --no-ipv4
WAITRESS_CALL --call
WAITRESS_THREADS --threads=$VAL
WAITRESS_IDENT --ident=$VAL
WAITRESS_OUTBUF_OVERFLOW --outbuf_high_watermark=$VAL
WAITRESS_INBUF_OVERFLOW --inbuf_overflow=$VAL
WAITRESS_CONNECTION_LIMIT --connection_limit=$VAL
WAITRESS_MAX_REQUEST_HEADER_SIZE --max_request_header_size=$VAL
WAITRESS_MAX_REQUEST_BODY_SIZE --max_request_body_size=$VAL
WAITRESS_ASYNCORE_LOOP_TIMEOUT --asyncore_loop_timeout=$VAL
WAITRESS_ASYNCORE_USE_POLL --asyncore_use_poll=$VAL

Where $VAL is the value passed into the environment. For example, to set the number of threads to 5 use:

docker run -d -p 80:80 -e WAITRESS_THREADS=5 myimage

Translates to command

waitress-serve --listen=*:80 --threads=5 app.wsgi:application

For those without any value, simply pass a 1. For example, to turn off IPv6 use:

docker run -d -p 80:80 -e WAITRESS_NO_IPV6=1 myimage

Translates to command

waitress-serve --listen=*:80 --no-ipv6 app.wsgi:application

Credits

This dockerfile setup is based on https://github.com/tiangolo/meinheld-gunicorn-docker

Waitress is one of the Pylons projects: https://pylonsproject.org

Python is by the Python Software Foundation. https://python.org

Docker is by Docker, Inc. https://docker.com

Built using open source software.

docker-python-waitress's People

Contributors

tecktron avatar mrv96 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.