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 automates infrastructure using Python. It’s fast and scales from one server to thousands. Great for ad-hoc command execution, service deployment, configuration management and more.


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.0b0.tar.gz (186.0 kB view details)

Uploaded Source

Built Distribution

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

pyinfra-3.0b0-py2.py3-none-any.whl (237.1 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

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

File hashes

Hashes for pyinfra-3.0b0.tar.gz
Algorithm Hash digest
SHA256 2755adbda1f5628cc6cfa598d93c601ec4a5b8e9cd6690beaacc26c0c9e45066
MD5 2607abec5e97895dbdd7f8882eb59856
BLAKE2b-256 ba97297816366aea37a6d9486b7191c27581e9736d7afa0d55eac58c1ec1e909

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyinfra-3.0b0-py2.py3-none-any.whl
  • Upload date:
  • Size: 237.1 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.0b0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3ba5825eaa15a45ff0c00f33d778b3d73a9509dd67bdba905b4137436ae5a89f
MD5 9eee9feda33994ac36af7d6865083128
BLAKE2b-256 8ce8c08f6d881e3a8fe356148bf05a24093fa5f269f31e5251b4a23ab1e83c27

See more details on using hashes here.

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