batou 2.5.0b3
pip install batou==2.5.0b3
Newer version available (2.5.4)
Released:
A utility for automating multi-host, multi-environment software builds and deployments.
Navigation
Unverified details
These details have not been verified by PyPIProject links
Meta
- License: BSD License (BSD (2-clause))
- Author: Christian Theune
- Tags deployment
- Requires: Python >=3.6
Classifiers
- License
- Programming Language
Project description
batou helps you to automate your application deployments:
- You create a model of your deployment using a simple but powerful Python API.
- You configure how the model applies to hosts in different environments.
- You verify and run the deployment with the batou utility.
Getting started with a new project is easy:
mkdir myproject
cd myproject
git init
curl -sL https://raw.githubusercontent.com/flyingcircusio/batou/main/bootstrap | sh
git commit -m "Start a batou project."
Here's a minimal application model:
$ mkdir -p components/myapp
$ cat > components/myapp/component.py
from batou.component import Component
from batou.lib.python import VirtualEnv, Package
from batou.lib.supervisor import Program
class MyApp(Component):
def configure(self):
venv = VirtualEnv('2.7')
self += venv
venv += Package('myapp')
self += Program('myapp',
command='bin/myapp')
And here's a minimal environment:
$ mkdir environments
$ cat > environments/dev/environment.cfg
[environment]
connect_method = local
[hosts]
localhost = myapp
To deploy this, you run:
$ ./batou deploy dev
Check the detailed documentation to get going with a more ambitious project.
Features
- Separate your application model from environments
- Supports idempotent operation for incremental deployments
- Deploy to multiple hosts simultaneously
- Automated dependency resolution for multi-host scenarios
- No runtime requirements on your application
- Encrypted secrets with multiple access levels: store your SSL certificates, SSH keys, service secrets and more to get true 1-button deployments.
- Deploy to local machines, Vagrant, or any SSH host
- Broad SSH feature support by using OpenSSH through execnet
- Only few dependencies required on the remote host
- Ships with a library of components for regularly needed tasks
- self-bootstrapping and self-updating - no additional scripting needed
License
The project is licensed under the 2-clause BSD license.
Hacking
- Make sure
mercurial
andsubversion
are installed and in$PATH
. - Run
./develop.sh
to create a local virtualenv with everything set up. - Run the test suite using:
bin/tox
- Build the documentation using:
cd doc; make
- Set up GPG for the examples with
export GNUPGHOME=<DIRECTORY OF BATOU HERE>/src/batou/secrets/tests/fixture/gnupg
- Make sure age is installed and in
$PATH
for age encryption support.
Changelog
See CHANGES.md.
Project details
Unverified details
These details have not been verified by PyPIProject links
Meta
- License: BSD License (BSD (2-clause))
- Author: Christian Theune
- Tags deployment
- Requires: Python >=3.6
Classifiers
- License
- Programming Language
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
File details
Details for the file batou-2.5.0b3.tar.gz
.
File metadata
- Download URL: batou-2.5.0b3.tar.gz
- Upload date:
- Size: 191.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 13847aeca656c8e7cc62267e6f4bfe821d5143e5370fb8088334ad7011c23268 |
|
MD5 | 3cc8f06cbff67a9a40b02588e0eac1cb |
|
BLAKE2b-256 | a5708b85dfeb0cfd80b816c2fae80a700e278402123544f7fee220cef71271ff |