Skip to main content

pyinfra automates/provisions/manages/deploys infrastructure.

Project description

pyinfra

Note: this is the v3 branch, which is currently in beta. See the docs for v3. If needed the 2.x branch is here, but is in bugfix only mode.

pyinfra turns Python code into shell commands and runs them on your servers. Execute ad-hoc commands and write declarative operations. Target SSH servers, local machine and Docker containers. Fast and scales from one server to thousands. Think ansible but Python instead of YAML, and a lot faster.


DocumentationGetting StartedExamplesHelp & SupportContributing

Chat ⇒ #pyinfra on Matrix


Why pyinfra? Design features include:

  • 🚀 Super fast execution over thousands of hosts with predictable performance.
  • 🚨 Instant debugging with realtime stdin/stdout/stderr output (-vvv).
  • 🔄 Idempotent operations that enable diffs and dry runs before making changes.
  • 📦 Extendable with the entire Python package ecosystem.
  • 💻 Agentless execution against anything with shell access.
  • 🔌 Integrated with connectors for Docker, Terraform, Vagrant and more.

Quickstart

Install pyinfra with pip:

pip install pyinfra

Now you can execute commands on hosts via SSH:

pyinfra my-server.net exec -- echo "hello world"

Or target Docker containers, the local machine, and other connectors:

pyinfra @docker/ubuntu exec -- echo "Hello world"
pyinfra @local exec -- echo "Hello world"

As well as executing commands you can define state using operations:

# Install iftop apt package if not present
pyinfra @docker/ubuntu apt.packages iftop update=true _sudo=true

Which can then be saved as a Python file like deploy.py:

from pyinfra.operations import apt

apt.packages(
    name="Ensure iftop is installed",
    packages=['iftop'],
    update=True,
    _sudo=True,
)

The hosts can also be saved in a file, for example inventory.py:

targets = ["@docker/ubuntu", "my-test-server.net"]

And executed together:

pyinfra inventory.py deploy.py

Now you know the building blocks of pyinfra! By combining inventory, operations and Python code you can deploy anything.

See the more detailed getting started or using operations guides. See how to use inventory & data, global arguments and the CLI or check out the documented examples.


PyPI version PyPi downloads Docs status Execute tests status Codecov Coverage MIT Licensed

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pyinfra-3.0b1.tar.gz (187.5 kB view details)

Uploaded Source

Built Distribution

pyinfra-3.0b1-py2.py3-none-any.whl (238.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pyinfra-3.0b1.tar.gz.

File metadata

  • Download URL: pyinfra-3.0b1.tar.gz
  • Upload date:
  • Size: 187.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pyinfra-3.0b1.tar.gz
Algorithm Hash digest
SHA256 9c690f65a25cab34e928f4007f5a7980a9bbbee25de257ad6da6e5bfde610d85
MD5 8cb5a95e555e54cfa32154dbd968943f
BLAKE2b-256 aed7cd9ea6a8e56b767a17925239779fbef99ba04789dd27c5d041c4f0b6e0be

See more details on using hashes here.

File details

Details for the file pyinfra-3.0b1-py2.py3-none-any.whl.

File metadata

  • Download URL: pyinfra-3.0b1-py2.py3-none-any.whl
  • Upload date:
  • Size: 238.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pyinfra-3.0b1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ada9f4f5779909dce48765973cd9ac3438e6715e85ae1612cd6710765219c435
MD5 1ab0b8ec728ed7de152e65a35374b40b
BLAKE2b-256 6e9754add8925f241d407b7b45a9cd6a826e1a124f385f4a10c33dd055de1c15

See more details on using hashes here.

Supported by

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