Skip to main content

pyinfra automates/provisions/manages/deploys infrastructure.

Project description

pyinfra

pyinfra automates infrastructure super fast at massive scale
ad-hoc command execution, service deployment, configuration management and more


DocumentationGetting StartedExamplesHelp & SupportContributing

Chat (both bridged) ⇒ #pyinfra on MatrixDiscord


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 executing any changes.
  • 📦 Extendable with any Python package as configured & written in standard Python.
  • 💻 Agentless execution against SSH/Docker/subprocess/WinRM hosts.
  • 🔌 Integrated with Docker, Terraform, Vagrant/Mech & Ansible out of the box.

When you run pyinfra you'll see something like (non animated version):

Quickstart

Install pyinfra with pipx (recommended) or pip:

pipx install pyinfra

Now you can execute commands on hosts via SSH:

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

Or execute in Docker, on 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-2.6.2.tar.gz (195.6 kB view details)

Uploaded Source

Built Distribution

pyinfra-2.6.2-py2.py3-none-any.whl (246.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pyinfra-2.6.2.tar.gz.

File metadata

  • Download URL: pyinfra-2.6.2.tar.gz
  • Upload date:
  • Size: 195.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for pyinfra-2.6.2.tar.gz
Algorithm Hash digest
SHA256 16a91358db837586a10615e853279da11bd7425f1dfed7804903c88ed1b95cb4
MD5 ad9223b90b74e8f91d85ed6ef68cebde
BLAKE2b-256 041c5678b93ff9cc605c6bc1ca346e849cbda69e3541ea22bf3a296742bb0c8d

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for pyinfra-2.6.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 cdc629a71226d93fbda71de1ced2d7474687e0a409c7c744d2471341691099b1
MD5 f6b86fad2dfebc54dc48593164e5fdea
BLAKE2b-256 10d326396f4f85ebe2ccdafe12a5c7baa6cfaa663303c2e15de2acde48ac8c0a

See more details on using hashes here.

Supported by

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