Skip to main content

Custom version for developing pyinfra

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


Download files

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

Source Distribution

pyinfra_forked_by_stone-w4tch3r-0.3.0.tar.gz (184.1 kB view details)

Uploaded Source

Built Distribution

pyinfra_forked_by_stone_w4tch3r-0.3.0-py2.py3-none-any.whl (240.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pyinfra_forked_by_stone-w4tch3r-0.3.0.tar.gz.

File metadata

File hashes

Hashes for pyinfra_forked_by_stone-w4tch3r-0.3.0.tar.gz
Algorithm Hash digest
SHA256 30bbb0af35f0f334de3f1b7d87ab043823c1cb7166331b0ed8d37fcfab13b4dd
MD5 e1d30afcf301983abe5a3791ae0eed48
BLAKE2b-256 f896dc6966b20a827110e26d7863830ea9cc006e65233bf7739337a8f6c0c272

See more details on using hashes here.

File details

Details for the file pyinfra_forked_by_stone_w4tch3r-0.3.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pyinfra_forked_by_stone_w4tch3r-0.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e76633c6609979c0cbbabf5f57f82ed303601f70c602b95af521f0a940ceccf7
MD5 97e203cd8291377b84cd0f56f0dfba3b
BLAKE2b-256 027477b883be0785445b4696a4434f0d89b2b97ec2df655b9d8f3c51e3ed85e9

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 Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page