Skip to main content

Utility to simplify Dockerfiles

Project description

Model W Docker

A tool so that your Dockerfile looks like this:

FROM modelw/base:2023.03

COPY --chown=user package.json package-lock.json ./

RUN modelw-docker install

COPY --chown=user . .

RUN modelw-docker build

CMD ["modelw-docker", "serve"]

Organization

This repository contains different elements that work together, found in sub-directories here:

  • src — Contains the source of the modelw-docker package, that is published on Pypi.
  • image — Is the source for the Docker image that can be used as a base for all Model W projects.
  • demo — A demo project used to test the image during development

modelw-docker

This is a helper that is pre-installed in the Docker image and helps you build and run a Model W project.

If called from the root of a project, it will automatically detect the project's type and run appropriate commands for each step of the build. If later on the way the Docker image is built or the requirements of Model W change, it is expected that those changes can be reflected in the modelw-docker package without requiring the developers to change their Dockerfiles.

Available actions

  • modelw-docker install — Installs the project's dependencies (creates the virtualenv, runs npm install or whatever is required). It only requires the dependencies files to run (package.json/package-lock.json for front components, pyproject.toml/poetry.lock for api components).
  • modelw-docker build — Builds the project. It requires the project to be installed first. It also requires all the source code to be present.
  • modelw-docker serve — Runs the project. It requires the project to be installed and built first.
  • modelw-docker run — Runs a command in the project's virtualenv. It requires the project to be installed first.

The reason why install and build are separate and why you need first to copy just the dependencies list and then the source code is to allow for caching of the dependencies. This way, the dependencies are only re-installed when the dependencies list changes, not when the source code changes. This makes very fast builds when only the source code changes.

Dry run

There is a --dry-run option for all the commands that will just print what would have been done but not do it. The dry run mode is automatically enabled if you run the package outside of Docker in order to avoid fucking up your desktop.

Config file

All the settings are automatically detected, however if something isn't to your taste you can always override it using a model-w.toml file, following this structure:

[project]
# For printing purposes
name = "demo_project"
# Either "front" or "api"
component = "api"

[project.required_files]
# All the files to be created before the install step and their content
"src/demo_project/__init__.py" = ""

[apt.repos]
# APT repositories to be added, you need to give both the source and the key
# for each one of them
pgdg.source = "deb http://apt.postgresql.org/pub/repos/apt/ bullseye-pgdg main"
pgdg.key = { url = "https://www.postgresql.org/media/keys/ACCC4CF8.asc" }

[apt.packages]
# APT packages to be installed. Put * to install the default version, or a
# version number to install a specific version.
gdal-bin = "*"

In addition, Python project also have the following settings:

[project]
# [...]
# Either "gunicorn" or "daphne"
server = "daphne"

# Modules that have the WSGI and ASGI entry points
wsgi = "demo_project.django.wsgi:application"
asgi = "demo_project.django.asgi:application"

Contribution

The Docker image and the package are auto-built and published on Docker Hub and Pypi respectively. The build is triggered by pushing a tag to the repository (for the Python package) and for each branch's head (for the Docker image).

If you want to make a release, the Makefile will help you:

make release VERSION=2022.10.0

This will use Git Flow to make the release, and then also make sure to update the version in the Dockerfile and the modelw-docker package.

Once this is done, you have to:

  • Push the tag to the repository
  • Push develop and master
  • Make sure you update support branches accordingly (this cannot be automated it's a human decision)

Note — If you're releasing a new major version of Model W, you need to update the image/Dockerfile to match the new "upper" version limit. This script will only update the "lower" version limit, to make sure the image is built with the package you just released.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

modelw_docker-2024.7.0b1.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

modelw_docker-2024.7.0b1-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file modelw_docker-2024.7.0b1.tar.gz.

File metadata

  • Download URL: modelw_docker-2024.7.0b1.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1022-azure

File hashes

Hashes for modelw_docker-2024.7.0b1.tar.gz
Algorithm Hash digest
SHA256 e80cc45a70d56c2adc9c84cb09229c8ef0ff1d334e6306f3f5ec80a630f341b0
MD5 e197a2b2d3d4e4709d274ad8ffc4eb7b
BLAKE2b-256 bf381fae3a772a932e70bd295eb6190b87a560468bbae78b280f06ec0670f22b

See more details on using hashes here.

Provenance

File details

Details for the file modelw_docker-2024.7.0b1-py3-none-any.whl.

File metadata

  • Download URL: modelw_docker-2024.7.0b1-py3-none-any.whl
  • Upload date:
  • Size: 16.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1022-azure

File hashes

Hashes for modelw_docker-2024.7.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 1acde36fc21d9d4f7fd44fa89d01f00801c9312cc8b760d2fd462311aab5083a
MD5 95bb2f8b74a22474f3aeba29daf6c6ce
BLAKE2b-256 e3a5cfc4a169d7707c85499992ca42a863ec7cb4b4b24c70cfb73d25d6376460

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page