docker7.1.0
docker7.1.0
Published
A Python library for the Docker Engine API.
pip install docker
Package Downloads
Authors
Project URLs
Requires Python
>=3.8
Dependencies
- pywin32
>=304; sys_platform == "win32"
- requests
>=2.26.0
- urllib3
>=1.26.0
- coverage
==7.2.7; extra == "dev"
- pytest-cov
==4.1.0; extra == "dev"
- pytest-timeout
==2.1.0; extra == "dev"
- pytest
==7.4.2; extra == "dev"
- ruff
==0.1.8; extra == "dev"
- myst-parser
==0.18.0; extra == "docs"
- sphinx
==5.1.1; extra == "docs"
- paramiko
>=2.4.3; extra == "ssh"
- websocket-client
>=1.3.0; extra == "websockets"
Docker SDK for Python
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. 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.