Skip to main content

pyinfra automates/provisions/manages/deploys infrastructure.

Project description

pyinfra

pyinfra automates infrastructure super fast at massive scale

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


DocumentationGetting StartedExamplesHelp & SupportContributing


pyinfra automates/provisions/manages/deploys infrastructure. It can be used for ad-hoc command execution, service deployment, configuration management and more. Design features include:

  • 🚀 Super fast execution over thousands of hosts with predictable performance.
  • 🚨 Instant debugging with stdout & stderr output on error or as required (-v|-vv|-vvv).
  • 📦 Extendable with any Python package as configured & written in standard Python.
  • 💻 Agentless execution against SSH/Docker/subprocess/winrm hosts.
  • ❗️ Two stage process that enables --dry runs before executing any changes.
  • 🔌 Integrated with Docker, 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.

Project details


Release history Release notifications | RSS feed

This version

2.0

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

Uploaded Source

Built Distribution

pyinfra-2.0-py2.py3-none-any.whl (225.6 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: pyinfra-2.0.tar.gz
  • Upload date:
  • Size: 173.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.4

File hashes

Hashes for pyinfra-2.0.tar.gz
Algorithm Hash digest
SHA256 af3562ad4ebdef019e84221cfd6c04e9183d01a61810b5dfa1ed7418c4451e0c
MD5 43e36f40d2a823d4e3770a35266eac52
BLAKE2b-256 bcc6a4ff29eaeb12f7f2aaa59975e79a6dab0b11137b8e986ab54c97c0073848

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyinfra-2.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 225.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.4

File hashes

Hashes for pyinfra-2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0cb64979da1bbecc27591a108585b126a75bc463bd69cddb5f1aa4068d0c2438
MD5 37c810dd5feae0afc97bfbf64c7a7413
BLAKE2b-256 cdfa16e35c172df3457e901772df4f2218cace16084fdbb17f51c55c630e66c3

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