ECMind Supervisor
Project description
- Distributed under GNU General Public License Version 3.
- Change log.
- This README.md is just boilerplate for the wiki.
Parameters
--bind: The ip/interface where suvi listens at. [default: 0.0.0.0]
--port: The listening port. [default: 8080]
--enforce / --no-enforce: Require a basic auth login [default: no-enforce]
--admin-login: Username for the admin user [default: admin]
--admin-password: Password for the admin user
--user-login: Username for the standard user [default: user]
--user-password: Password for the standard user
--tasks: Where to look for task config files (.json files) [default: ./tasks]
--cycle: Update interval in seconds to look for new/deleted task config files [default: 10]
--logs: Directory where to store suvi and task log files. [default: ./log]
--log-rotate-when: When to rotate log files (H for hours, D for days or midnight) [default: midnight]
--log-rotate-interval: How many instances fo when have to pass before rotating the log file [default: 1]
--log-backup-count: How many file rollovers should be stored [default: 5]
--help: Show help message and exit.
Using environment vars to configure suvi
Parameters can be set via environment vars, example:
#/bin/bash
PW1=$(pwmake 80)
PW2=$(pwmake 80)
echo Setting admin password to "$PW1" and user password to "$PW2".
SUVI_ENFORCE=True \
SUVI_ADMIN_LOGIN=admin \
SUVI_ADMIN_PASSWORD="$PW1" \
SUVI_USER_LOGIN=user \
SUVI_USER_PASSWORD="$PW2" \
suvi
Using suvi.toml to configure suvi
Parameters can also be set by a suvi.toml file:
bind = "0.0.0.0"
port = 8080
enforce = true
admin_login = "admin"
admin_password = "RamesesII"
user_login = "user"
user_password = "TrustNo1"
tasks = "./tasks"
cycle = 5
logs = "./log"
log_rotate_when = "midnight"
log_rotate_interval = 1
log_backup_count = 5
The values of the configuration file are overwritten by console values. For windows service deployments, suvi.toml is expected at %WINDIR%\system32.
Task config files (.json)
type: Defines the startup strategy"type": "ondemand": Run the task on user interaction/get call."type": "keepalive": Automatically start the task with suvi and restart if necessary."type": "schedule": Automatically start the task with suvi and restart if necessary.
exec: Defines how to start the task"exec": "system": Starts an external executable viapopen"exec": "shell": Starts an external executable viapopenin the current system shell.- The "
args" list should be joined and instead just separated by spaces for the shell to interpret the command.
- The "
"exec": "stop": Stops (= kill & reload) tasks by config file name i. e. on a schedule- Example:
{ "type": "schedule", "schedule": "* 0 * * *", "exec": "stop", "args": [ "has-to-restart-sometimes" ], "cwd": "/tmp" } "args"may contain one or more config files names without the json extension
- Example:
"exec": "talend": Deflates & starts a talend job build to a zip package- When using
"talend"for"exec", this additional config parameters exist:"package": Path to the talend build zip file."java": Optional path to the java binary. When this path to thejavabinary is omitted, the system default will be used.
- The
cwdparameter is used as base path for deflated jobs. Whencmdis omitted, the system default temp path is used instead. - Example:
{ "type": "keepalive", "exec": "talend", "package": "/jobs/talend-demo-job-with-subtask.zip", "args": ["--context=Test", "-Xms256M", "-Xmx1024M"], "cwd": "/tmp", "info": "deflate and keepalive talend demo job" }
- When using
args: Array of startup params or an array of arrays it multiple programs should be started if the previous job succeeded"args": ["notepad.exe", "test.txt"]"args": [ ["notepad.exe", "test.txt"], ["calc.exe"] ]
cwd: Optional startup path for the task"cwd": "C:/temp"
env: Optional dictionary that extends/overwrites suvis environment variables"env": {"TAIL_FILE": "/tmp/test"}, "args": ["bash", "-c", "tail -f $TAIL_FILE"]
schedule: Read when"type": "schedule"is set to launch an instance of the task if not already running.- minutes, hours, days, month, weekdays
"schedule": "0 0,4,8,12,16,20 * * 1-5": Start Monday to Friday on every four hours.- The crontab syntax element
/is not supported at the moment. - Minutes range from
0to59 - Hours range from
0to23 - Days range from
1to31 - Month range from
1(Jan) to12(Dec) - Weekdays range from
1(Mon) to7(Sun) including0(also Sun)
tokens: Optional list of secret tokens to start a tasks without a password via HTTP GET or POST at/run/hook/<token>- Example:
"tokens": ["30d827f9-e22f-4b6a-85f1-bcb9977c6155", "69f541f8-614a-45f4-950b-67998c819ee0"] - When POSTing to a webhook of
"exec": "system", the raw body gets redirected to STDIN of the (first)"args"command.
- Example:
info: Optional markdown text to provide task info.- Line breaks have to be encoded as
\nin JSON.
- Line breaks have to be encoded as
Environment variables of tasks
The environment variables for the runtime of a task consist of:
SUVI_TASK_NAMEset to the task name.SUVI_EXEC_UUIDset to a unique uuid for each task execution. This uuid is unchanged between executions of subtasks (whenargsis a list is lists).- Variables set by the OS
- Variables set by
envtask configuration.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file suvi-2.7.2.tar.gz.
File metadata
- Download URL: suvi-2.7.2.tar.gz
- Upload date:
- Size: 2.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd9d65c4e1b788c5b2e81e759c0b72459b336300fb68a3f6403835384232931a
|
|
| MD5 |
14ce540cfad890f8b0a6675bf34ec6dd
|
|
| BLAKE2b-256 |
aee2d98f12c0f2663a83d14453fc8fd55daac8ae84a30e7704ae1fc4ba79be47
|
File details
Details for the file suvi-2.7.2-py3-none-any.whl.
File metadata
- Download URL: suvi-2.7.2-py3-none-any.whl
- Upload date:
- Size: 183.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fb44b266d41ea40e4bbbf6ab4c05987d7e28df0c7ee28ea49cd2d72f96bdedac
|
|
| MD5 |
5bb583950b940152e32d17015ae5d8c6
|
|
| BLAKE2b-256 |
9e2ef5d568f5229507bc69106c7e235d5e1911cca54239f18508278ed30b7176
|