A Python library for the Docker Engine API
Go to file
Sebastiaan van Stijn ee2310595d
test: remove APT_MIRROR from Dockerfile (#3145)
The official Python images on Docker Hub switched to debian bookworm,
which is now the current stable version of Debian.

However, the location of the apt repository config file changed, which
causes the Dockerfile build to fail;

    Loaded image: emptyfs:latest
    Loaded image ID: sha256:0df1207206e5288f4a989a2f13d1f5b3c4e70467702c1d5d21dfc9f002b7bd43
    INFO: Building docker-sdk-python3:5.0.3...
    tests/Dockerfile:6
    --------------------
       5 |     ARG APT_MIRROR
       6 | >>> RUN sed -ri "s/(httpredir|deb).debian.org/${APT_MIRROR:-deb.debian.org}/g" /etc/apt/sources.list \
       7 | >>>     && sed -ri "s/(security).debian.org/${APT_MIRROR:-security.debian.org}/g" /etc/apt/sources.list
       8 |
    --------------------
    ERROR: failed to solve: process "/bin/sh -c sed -ri \"s/(httpredir|deb).debian.org/${APT_MIRROR:-deb.debian.org}/g\" /etc/apt/sources.list     && sed -ri \"s/(security).debian.org/${APT_MIRROR:-security.debian.org}/g\" /etc/apt/sources.list" did not complete successfully: exit code: 2

The APT_MIRROR build-arg was originally added when the Debian package
repositories were known to be unreliable, but that hasn't been the
case for quite a while, so let's remove this altogether.

Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
Signed-off-by: Milas Bowman <milas.bowman@docker.com>
Co-authored-by: Milas Bowman <milas.bowman@docker.com>
2023-08-14 15:12:44 -04:00
.github ci: add support for Python 3.11 (#3064) 2022-11-15 08:10:56 -05:00
docker feat: add pause option to commit api (#3159) 2023-08-14 14:52:38 -04:00
docs fix user_guides/multiplex.rst (#3130) 2023-06-06 14:28:15 -04:00
scripts use python3.6+ constructs 2021-07-05 18:30:07 -04:00
tests test: remove APT_MIRROR from Dockerfile (#3145) 2023-08-14 15:12:44 -04:00
.coveragerc Add coverage 2014-07-11 16:13:00 +02:00
.dockerignore Makes docs builds faster and ensures proper ownership 2017-04-15 15:46:52 +02:00
.editorconfig ci: add workflow for releases (#3018) 2022-07-30 12:14:27 -04:00
.gitignore ci: add workflow for releases (#3018) 2022-07-30 12:14:27 -04:00
.readthedocs.yml docs: install package in ReadTheDocs build (#3032) 2022-08-18 17:03:32 -04:00
CONTRIBUTING.md Rename non-URL occurrences of docker-py to "Docker SDK for Python" 2016-12-12 13:28:49 -08:00
Dockerfile ci: use latest stable syntax for Dockerfiles (#3035) 2022-08-19 15:09:12 -04:00
Dockerfile-docs ci: use latest stable syntax for Dockerfiles (#3035) 2022-08-19 15:09:12 -04:00
Jenkinsfile deps: test on Python 3.10 by default (#3010) 2022-07-27 14:44:36 -04:00
LICENSE Fix licenses 2016-09-05 17:48:09 +02:00
MAINTAINERS Update maintainers 2021-04-06 16:01:16 +02:00
MANIFEST.in Make dockerpycreds part of the SDK under docker.credentials 2019-04-30 23:37:55 -07:00
Makefile ci: run SSH integration tests (#3012) 2022-07-27 16:25:27 -04:00
README.md README: fix link for CI status badge 2023-08-14 14:58:34 +02:00
docs-requirements.txt docs: fix markdown rendering (#3020) 2022-07-28 16:38:57 -04:00
pyproject.toml ci: add workflow for releases (#3018) 2022-07-30 12:14:27 -04:00
pytest.ini pytest: update to v4.2.1 - use xunit2 for compatibility with Jenkins 2019-08-11 02:13:30 +02:00
requirements.txt build(deps): Bump requests from 2.28.1 to 2.31.0 (#3136) 2023-08-14 15:08:38 -04:00
setup.cfg Universal wheels are for code expected to work on both Python 2 and 3 2021-10-11 23:06:12 +03:00
setup.py ci: add support for Python 3.11 (#3064) 2022-11-15 08:10:56 -05:00
test-requirements.txt build(deps): Bump setuptools from 63.2.0 to 65.5.1 (#3082) 2023-01-10 17:25:12 -05:00
tox.ini ci: add support for Python 3.11 (#3064) 2022-11-15 08:10:56 -05:00

README.md

Docker SDK for Python

Build Status

A Python library for the Docker Engine API. It lets you do anything the docker command does, but from within Python apps run containers, manage containers, manage Swarms, etc.

Installation

The latest stable version is available on PyPI. Either add docker to your requirements.txt file or install with pip:

pip install docker

Older versions (< 6.0) required installing docker[tls] for SSL/TLS support. This is no longer necessary and is a no-op, but is supported for backwards compatibility.

Usage

Connect to Docker using the default socket or the configuration in your environment:

import docker
client = docker.from_env()

You can run containers:

>>> client.containers.run("ubuntu:latest", "echo hello world")
'hello world\n'

You can run containers in the background:

>>> client.containers.run("bfirsh/reticulate-splines", detach=True)
<Container '45e6d2de7c54'>

You can manage containers:

>>> client.containers.list()
[<Container '45e6d2de7c54'>, <Container 'db18e4f20eaa'>, ...]

>>> container = client.containers.get('45e6d2de7c54')

>>> container.attrs['Config']['Image']
"bfirsh/reticulate-splines"

>>> container.logs()
"Reticulating spline 1...\n"

>>> container.stop()

You can stream logs:

>>> for line in container.logs(stream=True):
...   print(line.strip())
Reticulating spline 2...
Reticulating spline 3...
...

You can manage images:

>>> client.images.pull('nginx')
<Image 'nginx'>

>>> client.images.list()
[<Image 'ubuntu'>, <Image 'nginx'>, ...]

Read the full documentation to see everything you can do.