Custom version for developing pyinfra
Project description
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.
Documentation ⇒ Getting Started • Examples • Help & Support • Contributing
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.
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
Built Distribution
File details
Details for the file pyinfra_forked_by_stone-w4tch3r-0.3.1.tar.gz
.
File metadata
- Download URL: pyinfra_forked_by_stone-w4tch3r-0.3.1.tar.gz
- Upload date:
- Size: 184.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9c54942335e44074e070303ba5bad3097e5aca3e68489ed385665307450c2622 |
|
MD5 | c6eaeb6dce9c2809a3060103f621df96 |
|
BLAKE2b-256 | 4b3032f09b56c37010801f429b0f077a3c0478c9d81750bf7963e5b99d8445e1 |
File details
Details for the file pyinfra_forked_by_stone_w4tch3r-0.3.1-py2.py3-none-any.whl
.
File metadata
- Download URL: pyinfra_forked_by_stone_w4tch3r-0.3.1-py2.py3-none-any.whl
- Upload date:
- Size: 240.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c238b45fa03f89364b41e12b4ff59e30e51279805e9284749b4af0786c1be396 |
|
MD5 | 77490c4c753dbd3c998f54eefd3b85e3 |
|
BLAKE2b-256 | fb1478658a6a775eceabc497300b4df35e8d92eaece700a62c1adb254ef76379 |