Skip to main content

Use docker-compose (V2) from within Python

Project description

Docker Composer

A library to interact with docker-compose V2 from a python Program. All commands and parameters are exposed as python classes and attributes to allow for full auto-completion of its parameters with IDEs that support it.

Install

pip install docker-composer

Usage

The main class is docker_composer.DockerCompose. Its parameters are all options from docker-compose.

Each docker-compose command has a corresponding function, e.g. DockerCompose.run or DockerCompose.scale. Their arguments again mirror the options of the corresponding command.

The resulting object has a call function. It takes arbitrary strings as input, as well as all keyword arguments from subprocess.run, and returns a subprocess.CompletedProcess

from docker_composer import DockerCompose


base = DockerCompose(file="docker-compose.yml", verbose=True)
base.run(detach=True, workdir="/tmp").call("app")
base.run(workdir="/tmp").call("app", "/bin/bash", "-l")

# /tmp $ ls /.dockerenv
# /.dockerenv
# /tmp $ exit

process = base.ps(all=True).call(capture_output=True)
print(process.stdout.encode("UTF-8"))
#          Name                      Command           State    Ports
# -------------------------------------------------------------------
# myapp_app_70fd8b786b76   myapp --start-server        Exit 0        
# myapp_app_6ac3db4e1b55   myapp --client              Exit 0   

Develop

Development Setup

The generate extra is maintainer tooling for code generation/formatting and is not required for normal package usage.

uv sync --group dev --extra generate

If you only need the generation tooling, you can install just the extra:

uv sync --extra generate

Coding Standards

Type Package Comment
Linter ruff Also for auto-formatted modules
Logging logging
Packaging uv
Tests pytest
Typing mypy Type all methods
Imports ruff

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

docker_composer-5.1.0.tar.gz (26.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

docker_composer-5.1.0-py3-none-any.whl (40.1 kB view details)

Uploaded Python 3

File details

Details for the file docker_composer-5.1.0.tar.gz.

File metadata

  • Download URL: docker_composer-5.1.0.tar.gz
  • Upload date:
  • Size: 26.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for docker_composer-5.1.0.tar.gz
Algorithm Hash digest
SHA256 05233139faf3afaf848a299df9ddd8284a486890392743dfdfd29ccc903a5263
MD5 2d172ece142c99c74ec4233f180fa139
BLAKE2b-256 00f6a6e9b1d3ad9844c54afa0bb7f9e8aba6ee99eb16679d4356d53c9b80518a

See more details on using hashes here.

Provenance

The following attestation bundles were made for docker_composer-5.1.0.tar.gz:

Publisher: python.yml on schollm/docker-composer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file docker_composer-5.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for docker_composer-5.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c7cc09f725f33f0e8fdefcef2b73e85d1c24bd6075b5c28a7d89f9df6667de2b
MD5 54da4d181f8e7dfa2e3010871a4c5b5d
BLAKE2b-256 d49cf845cceb43bd88b514a9a3ea2a29a481fab0b2a7ce9f11371da628bd8d9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for docker_composer-5.1.0-py3-none-any.whl:

Publisher: python.yml on schollm/docker-composer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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