Process manager
Project description
Encab: A Simple Process Manager
Encab is a process manager that simplifies running multiple services in a container or from the command line.
It's essentially a replacement for complex, hand-written Docker Container Entrypoint scripts, especially when dockerizing complex legacy applications.
- Add it as your Dockerfile Entrypoint,
together with the encab configuration file
encab.yml
,
...
ADD encab.yml .
ENTRYPOINT ["encab"]
- Define what you want to run in your container in
encab.yml
,
programs:
cron:
command: cron -f
main:
command: httpd-foreground
and encab cares for the rest. Run it and you'll always know who's logging what...
INFO encab: encab 0.0.8
INFO encab: Using configuration file ./encab.yml, source: Default location.
ERROR main: AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using 172.17.0.2. Set the 'ServerName' directive globally to suppress this message
ERROR main: AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using 172.17.0.2. Set the 'ServerName' directive globally to suppress this message
ERROR main: [Wed Jan 18 09:47:12.417275 2023] [mpm_event:notice] [pid 12:tid 140142563044672] AH00489: Apache/2.4.54 (Unix) configured -- resuming normal operations
ERROR main: [Wed Jan 18 09:47:12.417830 2023] [core:notice] [pid 12:tid 140142563044672] AH00094: Command line: 'httpd -D FOREGROUND'
INFO cron: Hello Wed Jan 18 09:48:01 UTC 2023
It shares some similarities with supervisord which I've used before I wrote encab but supervisord is a process controll system not designed to run in a Container environment.
Note
This tool is still under development. Sufficient for local experiments but not mature enough for production use!
Features
- run multiple programs in a container at a time with transparent logging
- run programs as different users
- handle environment variables in a flexible way
- simplify container debugging
- load, build, validate environment variables
Documentation
Installation
Install locally
Prerequisites
- Python Version >= 3.7
- activated Python virtual environment such as miniconda or virtualenv
pip install -U encab
Run locally
- Create sample encab file
encab.yml
encab:
dry_run: false
programs:
main:
sh:
- echo "Hello Encab!"
- Run locally:
encab
The result will be something like this:
INFO encab: encab 0.0.8
INFO encab: Using configuration file ./encab.yml, source: Default location.
INFO main: Hello Encab!
INFO main: Exited with rc: 0
Install in Container
Prerequisites
- Docker from your Linux distribution or Docker Desktop.
Run in Container
- Create sample encab file
encab.yml
encab:
dry_run: false
programs:
main:
sh:
- echo "Hello Encab!"
-
Add Encab to your Docker file.
FROM python:3.10.8-slim-bullseye # -------------------------------------------- # Install Venv # ENV VIRTUAL_ENV=/opt/encabenv ENV PATH="$VIRTUAL_ENV/bin:$PATH" RUN python3 -m venv $VIRTUAL_ENV && \ pip install --upgrade pip # -------------------------------------------- # Install Encab # RUN pip install encab # ------------------------------------------- # add configuration file # ADD encab.yml . # ------------------------------------------- # set encab as entrypoint ENTRYPOINT ["encab"]
-
Build container
docker build -t encab_minimum .
-
Run container
docker run encab_minimum
Result:
INFO encab: encab 0.0.8 INFO encab: Using configuration file ./encab.yml, source: Default location. INFO main: Hello world! INFO main: Exited with rc: 0
Similar Projects
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
Built Distribution
File details
Details for the file encab-0.0.8.tar.gz
.
File metadata
- Download URL: encab-0.0.8.tar.gz
- Upload date:
- Size: 23.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d8dacb3e8a8647f05f5a892f5d2ac5d11ecea63c665333eff15a03b625a03b5c |
|
MD5 | 40c965925e4b429616fd492e0a18dd61 |
|
BLAKE2b-256 | 1024dd110e509c15e4ee6ab13ad682eb824868e7e91a7c98babd47610d78da03 |
File details
Details for the file encab-0.0.8-py3-none-any.whl
.
File metadata
- Download URL: encab-0.0.8-py3-none-any.whl
- Upload date:
- Size: 27.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 36e5dc29e11cea97669b64cf1d468e0fe3b14661b90c9c3772cb91596a893b45 |
|
MD5 | 9499db0d3ff5a9957447612633dccbca |
|
BLAKE2b-256 | efb44ced8264ba4e6f332974ffc782d7702dfbe46703c1423618227a5783409c |