Management command to build and deploy webapps, especially based on Django
Project description
mantis-cli
Mantis is a CLI (command line interface) tool designed as a wrapper upon docker and docker compose commands for your project.
Using few commands you can:
- encrypt and decrypt your environment files
- build and push docker images
- create docker contexts
- zero-downtime deploy your application
- print logs of your containers
- connect to bash of your containers using SSH
- clean docker resources
- use specific commands using Django, PostgreSQL and Nginx extensions
- and much more
Installation
pip install mantis-cli
Configuration
Create a mantis.json configuration file in JSON format.
You can use <MANTIS> variable in your paths if needed as a relative reference to your mantis file.
Explanation of config arguments
| argument | type | description |
|---|---|---|
| manager_class | string | class path to mantis manager class |
| extensions | dict | Django, Postgres, Nginx |
| encryption | dict | encryption settings |
| encryption.deterministic | bool | if True, encryption hash is always the same for same value |
| encryption.folder | bool | path to folder with your environment files |
| configs | dict | configuration settings |
| configs.folder | string | path to folder with your configuration files |
| build | dict | build settings |
| build.tool | string | "docker" or "compose" |
| compose | dict | docker compose settings |
| compose.command | string | standalone "docker-compose" or "docker compose" plugin |
| compose.folder | string | path to folder with compose files |
| environment | dict | environment settings |
| environment.folder | string | path to folder with environment files |
| environment.file_prefix | string | file prefix of environment files |
| zero_downtime | array | list of services to deploy with zero downtime |
| project_path | string | path to folder with project files on remote server |
| connection | string | single connection string (use instead of connections) |
| connections | dict | definition of your connections for each environment |
TODO:
- default values
See template file for exact JSON structure.
Connections
Mantis supports two connection modes: multi-environment and single connection.
Multi-environment mode
Use connections (dict) when you have multiple environments like stage, production, etc.:
"connections": {
"stage": "context://<context_name>",
"production": "ssh://<user>@<host>:<port>"
}
In this mode, you must specify the environment in every command:
mantis -e production status
mantis -e stage deploy
Single connection mode
Use connection (string) when you only have one environment. This simplifies the CLI usage by making the environment parameter optional:
"connection": "ssh://<user>@<host>:<port>"
In this mode, you can run commands without specifying an environment:
mantis status
mantis deploy
Environment files are looked up directly in the environment.folder instead of environment-specific subfolders.
Note: You cannot define both connection and connections in the same config file.
Encryption
If you plan to use encryption and decryption of your environment files, you need to create encryption key.
Generation of new key:
mantis generate-key
Save key to mantis.key file:
echo <MANTIS_KEY> > /path/to/encryption/folder/mantis.key
Then you can encrypt your environment files using symmetric encryption. Every environment variable is encrypted separately instead of encrypting the whole file for better tracking of changes in VCS.
mantis -e <ENVIRONMENT> encrypt-env
Decryption is easy like this:
mantis -e <ENVIRONMENT> decrypt-env
When decrypting, mantis prompts user for confirmation. You can bypass that by forcing decryption which can be useful in CI/CD pipeline:
mantis -e <ENVIRONMENT> decrypt-env --force
Usage
General usage of mantis-cli has this format:
mantis [OPTIONS] COMMAND [ARGS]... [+ COMMAND [ARGS]...]
Use + to chain multiple commands:
mantis -e production build + push + deploy
Options
| Option | Description |
|---|---|
| --env, -e | Environment ID (e.g., stage, production) |
| --mode, -m | Execution mode: remote (default), ssh, host |
| --dry-run, -n | Show commands without executing |
| --version, -v | Show version and exit |
| --help, -h | Show help message |
Modes
Mantis can operate in 3 different modes depending on how it connects to remote machine:
Remote mode --mode=remote
Runs commands remotely from local machine using DOCKER_HOST or DOCKER_CONTEXT (default)
SSH mode --mode=ssh
Connects to host via SSH and runs all mantis commands on remote machine directly (mantis-cli needs to be installed on server)
Host mode --mode=host
Runs mantis on host machine directly without invoking connection (used as proxy for ssh mode)
Environments
Environment can be either local or any custom environment like stage, production etc. The environment is also used as an identifier for remote connection.
Commands
Run mantis --help to see all available commands with their descriptions.
Core commands:
| Command / Shortcut | Description |
|---|---|
| status / s | Prints images and containers |
| deploy [--dirty] [--strategy] / d | Runs deployment process |
| rolling-update [service] / ru | Performs rolling update of containers one-by-one |
| clean [params...] / c | Clean images, containers, networks |
Files:
| Command / Shortcut | Description |
|---|---|
| upload / u | Uploads config, compose and env files to server |
Images:
| Command / Shortcut | Description |
|---|---|
| build [SERVICES...] / b | Builds all services with Dockerfiles |
| pull [SERVICES...] / pl | Pulls required images for services |
| push [SERVICES...] / p | Push built images to repository |
| get-image-name SERVICE | Gets image name for service |
Containers:
| Command / Shortcut | Description |
|---|---|
| logs [CONTAINER] / l | Prints logs of containers |
| networks / n | Prints docker networks |
| healthcheck [CONTAINER] / hc | Execute health-check of container |
| stop [CONTAINERS...] | Stops containers |
| start [CONTAINERS...] | Starts containers |
| kill [CONTAINERS...] | Kills containers |
| remove [CONTAINERS...] [--force] | Removes containers |
| rename CONTAINER NEW_NAME | Rename container |
| bash CONTAINER | Runs bash in container |
| sh CONTAINER | Runs sh in container |
| exec CONTAINER COMMAND... | Executes command in container |
| exec-it CONTAINER COMMAND... | Executes command in container (interactive) |
| get-container-name SERVICE | Gets container name for service |
| remove-suffixes [PREFIX] | Removes numerical suffixes from container names |
Compose:
| Command | Description |
|---|---|
| up [PARAMS...] | Calls compose up |
| down [PARAMS...] | Calls compose down |
| run PARAMS... | Calls compose run with params |
Services:
| Command | Description |
|---|---|
| restart [SERVICE] | Restarts containers |
| scale SERVICE NUM | Scales service to given number |
| zero-downtime [SERVICE] | Runs zero-downtime deployment |
| restart-service SERVICE | Restarts a specific service |
| services | Lists all defined services |
| services-to-build | Lists services that will be built |
Volumes:
| Command | Description |
|---|---|
| backup-volume VOLUME | Backups volume to a file |
| restore-volume VOLUME FILE | Restores volume from a file |
Secrets:
| Command | Description |
|---|---|
| show-env [KEYWORD] | Shows environment variables from .env files |
| encrypt-env [--force] | Encrypts environment files |
| decrypt-env [--force] | Decrypts environment files |
| check-env | Compares encrypted and decrypted env files |
| generate-key | Creates new encryption key |
| read-key | Returns encryption key value |
Configuration:
| Command | Description |
|---|---|
| show-config | Shows the JSON mantis config |
| check-config | Validates config file |
Connections:
| Command | Description |
|---|---|
| contexts | Prints all docker contexts |
| create-context | Creates docker context |
| ssh | Connects to remote host via SSH |
Django extension:
| Command | Description |
|---|---|
| shell | Runs Django shell |
| manage [OPTIONS] CMD [ARGS...] | Runs Django manage command |
| send-test-email | Sends test email to admins |
| reset-migrations | Clears migration history and fakes all migrations |
The manage command supports health-check options:
--if-healthy: Only execute if the container is currently healthy. Skips with a warning if not healthy.--healthy-timeout N: Wait up to N seconds for the container to become healthy before executing. Polls every second and skips the command if the timeout is reached.
PostgreSQL extension:
| Command | Description |
|---|---|
| psql | Starts psql console |
| pg-dump [--data-only] [--table] | Backups PostgreSQL database |
| pg-dump-data [--table] | Backups PostgreSQL database (data only) |
| pg-restore FILENAME [--table] | Restores database from backup |
| pg-restore-data FILENAME TABLE | Restores database data from backup |
Nginx extension:
| Command | Description |
|---|---|
| reload-webserver | Reloads nginx webserver |
Examples
mantis --version
mantis -e local encrypt-env
mantis -e stage build
mantis -e production logs web
# Run multiple commands using + separator
mantis -e stage build + push + deploy
mantis -e stage build web api + push + deploy + status
# Commands with arguments
mantis -e production deploy --dirty
mantis -e production manage migrate
mantis -e production manage --healthy-timeout 60 migrate
mantis -e production pg-dump --data-only --table users
# Single connection mode (no environment needed)
mantis status
mantis deploy
Check mantis --help for more details, or mantis COMMAND --help for command-specific help.
Flow
1. Build
Once you define mantis config for your project and optionally create encryption key, you can build your docker images:
mantis -e <ENVIRONMENT> build
Mantis either uses docker-compose --build or docker build command depending on build tool defined in your config.
Build image names use '_' as word separator.
2. Push
Built images needs to be pushed to your repository defined in compose file (you need to authenticate)
mantis -e <ENVIRONMENT> push
3. Deployment
Deployment to your remote server is being executed by calling simple command:
mantis -e <ENVIRONMENT> deploy
Or chain all steps together:
mantis -e <ENVIRONMENT> build + push + deploy
The deployment process consists of multiple steps:
- If using --mode=ssh, mantis uploads mantis config, environment files and compose file to server
- pulling docker images from repositories
- zero-downtime deployment of running containers (if any)
- calling docker compose up to start containers
- removing numeric suffixes from container names (if scale==1)
- reloading webserver (if found suitable extension)
- cleaning docker resources (without volumes)
Docker container names use '-' as word separator (docker compose v2 convention).
4. Inspect
Once deployed, you can verify the container status:
mantis -e <ENVIRONMENT> status
list all docker networks:
mantis -e <ENVIRONMENT> networks
and also check all container logs:
mantis -e <ENVIRONMENT> logs
If you need to follow logs of a specific container, you can do it by passing container name to command:
mantis -e <ENVIRONMENT> logs <container-name>
5. Another useful commands
Sometimes, instead of calling whole deployment process, you just need to call compose commands directly:
mantis -e <ENVIRONMENT> up
mantis -e <ENVIRONMENT> down
mantis -e <ENVIRONMENT> restart
mantis -e <ENVIRONMENT> stop
mantis -e <ENVIRONMENT> kill
mantis -e <ENVIRONMENT> start
mantis -e <ENVIRONMENT> clean
Commands over a single container:
mantis -e <ENVIRONMENT> bash <container-name>
mantis -e <ENVIRONMENT> sh <container-name>
mantis -e <ENVIRONMENT> run <params>
Zero-downtime deployment
Mantis has own zero-downtime deployment implementation without any third-party dependencies. It uses docker compose service scaling and docker health-checks.
Works as follows:
- a new service container starts using scaling
- mantis waits until the new container is healthy by checking its health status. If not health-check is defined, it waits X seconds defined by start period
- reloads webserver (to proxy requests to new container)
- once container is healthy or start period ends the old container is stopped and removed
- new container is renamed to previous container's name
- webserver is reloaded again
Release notes
Mantis uses semantic versioning. See more in changelog.
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
File details
Details for the file mantis_cli-22.0.1.tar.gz.
File metadata
- Download URL: mantis_cli-22.0.1.tar.gz
- Upload date:
- Size: 59.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bdf294bff8dbff39f3233de925eb0e9ad50d9a7b2c35d40aca091bc4f7b4f6b3
|
|
| MD5 |
f845e97c9cb9e406809364d8f4903856
|
|
| BLAKE2b-256 |
d12310615c06c56094dee2896031e026a8fde04ae6ab9d66b5c67514ec1a3542
|