Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

mantis-cli

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

mantis-cli

Management command to build and deploy webapps, especially based on Django

  • 19.2.0
  • PyPI
  • Socket score

Maintainers
1

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

argumenttypedescription
manager_classstringclass path to mantis manager class
extensionsdictDjango, Postgres, Nginx
encryptiondictencryption settings
encryption.deterministicboolif True, encryption hash is always the same for same value
encryption.folderboolpath to folder with your environment files
configsdictconfiguration settings
configs.folderstringpath to folder with your configuration files
builddictbuild settings
build.toolstring"docker" or "compose"
composedictdocker compose settings
compose.commandstringstandalone "docker-compose" or "docker compose" plugin
compose.folderstringpath to folder with compose files
environmentdictenvironment settings
environment.folderstringpath to folder with environment files
environment.file_prefixstringfile prefix of environment files
zero_downtimearraylist of services to deploy with zero downtime
project_pathstringpath to folder with project files on remote server
connectionsdictdefinition of your connections for each environment

TODO:

  • default values

See template file for exact JSON structure.

Connections

Connection for each environment except localhost can be defined either as an SSH or Docker context:

For example:

"connections": {
    "stage": "context://<context_name>",
    "production": "ssh://<user>@<host>:<port>"
}

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 <ENVIRONMENT> --encrypt-env

Decryption is easy like this:

mantis <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 <ENVIRONMENT> --decrypt-env:force

Usage

General usage of mantis-cli has this format:

mantis [--mode=remote|ssh|host] [environment] --command[:params]

Modes

Mantis can operate in 3 different modes depending on a way it connects to remote machhine

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 run all mantis commands on remote machine directly (nantis-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

Command / ShortcutDescription
--bash:paramsRuns bash in container
--build[:params] / -bBuilds all services with Dockerfiles
--check-configValidates config file according to template
--check-envCompares encrypted and decrypted env files
--check-health:containerChecks current health of given container
--clean[:params] / -cClean images, containers, networks
--contextsPrints all docker contexts
--create-contextCreates docker context using user inputs
--decrypt-env[:params,env_file,return_value]Decrypts all environment files (force param skips user confirmation)
--deploy[:dirty] / -dRuns deployment process: uploads files, pulls images, runs zero-downtime deployment, removes suffixes, reloads webserver, clean
--down[:params]Calls compose down (with optional params)
--encrypt-env[:params,env_file,return_value]Encrypts all environment files (force param skips user confirmation)
--exec:paramsExecutes command in container
--generate-keyCreates new encryption key
--get-container-name:serviceConstructs container name with project prefix for given service
--get-container-suffix:serviceReturns the suffix used for containers for given service
--get-deploy-replicas:serviceReturns default number of deploy replicas of given services
--get-healthcheck-config:containerPrints health-check config (if any) of given container
--get-healthcheck-start-period:containerReturns healthcheck start period for given container (if any)
--get-image-name:serviceConstructs image name for given service
--get-image-suffix:serviceReturns the suffix used for image for given service
--get-number-of-containers:servicePrints number of containers for given service
--get-service-containers:servicePrints container names of given service
--has-healthcheck:containerChecks if given container has defined healthcheck
--healthcheck[:container] / -hcExecute health-check of given project container
--kill[:params]Kills all or given project container
--logs[:params] / -lPrints logs of all or given project container
--manage:paramsRuns Django manage command
--networks / -nPrints docker networks
--pg-dump[:data_only,table]Backups PostgreSQL database [data and structure]
--pg-dump-data[:table]Backups PostgreSQL database [data only]
--pg-restore[:filename,table]Restores database from backup [data and structure]
--pg-restore-data:paramsRestores database from backup [data only]
--psqlStarts psql console
--pull[:params] / -pPulls required images for services
--push[:params]Push built images to repository
--read-keyReturns value of mantis encryption key
--remove[:params]Removes all or given project container
--remove-suffixes[:prefix]Removes numerical suffixes from container names (if scale == 1)
--restart[:service]Restarts all containers by calling compose down and up
--restart-service:serviceStops, removes and recreates container for given service
--run:paramsCalls compose run with params
--scale:service,scaleScales service to given scale
--send-test-emailSends test email to admins using Django 'sendtestemail' command
--servicesPrints all defined services
--services-to-buildPrints all services which will be build
--sh:paramsRuns sh in container
--shellRuns and connects to Django shell
--start[:params]Starts all or given project container
--status / -sPrints images and containers
--stop[:params]Stops all or given project container
--try-to-reload-webserverTries to reload webserver (if suitable extension is available)
--up[:params]Calls compose up (with optional params)
--upload / -uUploads mantis config, compose file
and environment files to server
--zero-downtime[:service]Runs zero-downtime deployment of services (or given service)
--backup-volume:volumeBackups volume to a file
--restore-volume:volume,fileRestores volume from a file

Few examples:

mantis --version
mantis local --encrypt-env
mantis stage --build
mantis production --logs:container-name

# you can also run multiple commands at once
mantis stage --build --push --deploy -s -l

Check mantis --help for more details.

Flow

1. Build

Once you define mantis config for your project and optionally create encryption key, you can build your docker images:

mantis <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 <ENVIRONMENT> --push

3. Deployment

Deployment to your remote server is being executed by calling simple command:

mantis <ENVIRONMENT> --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 <ENVIRONMENT> --status

list all docker networks:

mantis <ENVIRONMENT> --networks

and also check all container logs:

mantis <ENVIRONMENT> --logs

If you need to follow logs of a specific container, you can do it by passing container name to command:

mantis <ENVIRONMENT> --logs:<container-name>

5. Another useful commands

Sometimes, instead of calling whole deployment process, you just need to call compose commands directly:

mantis <ENVIRONMENT> --up
mantis <ENVIRONMENT> --down
mantis <ENVIRONMENT> --restart
mantis <ENVIRONMENT> --stop
mantis <ENVIRONMENT> --kill
mantis <ENVIRONMENT> --start
mantis <ENVIRONMENT> --clean

Commands over a single container:

mantis <ENVIRONMENT> --bash:container-name
mantis <ENVIRONMENT> --sh:container-name
mantis <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.

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc