Watchmen 是一个守护进程管理器,可为您全天候管理和保持应用程序在线
# 获取源码
git clone https://github.com/ahriroot/watchmen.git
# 进入项目目录
cd watchmen
# 安装守护进程
cargo install --path watchmend
# 安装 cli 工具
cargo install --path watchmen# 安装守护进程
cargo install watchmend
# 安装 cli 工具
cargo install watchmennpm install -g watchmen-rustpip install watchmen-rust"" 默认位置 ${HOME}/.watchmen/config.toml
watchmen -g ""
[watchmen]
# The engine to use for the watchmen server
# Valid values are "sock", "socket", "http", "redis"
# sock: Unix socket
# socket: TCP socket
# http: HTTP Api (Include Web panel)
# redis: Redis pub/sub
engines = ["sock"]
# The default engine to use for connecting to the watchmen server
engine = "sock"
# The log directory of the watchmen server
log_dir = "$HOME/.watchmen/logs"
# The log level of the watchmen server
# Valid values are "debug", "info", "warn", "error". Default is "info"
log_level = "info"
# The standard output of the watchmen server
# Default is None
stdout = "$HOME/.watchmen/watchmen.stdout.log"
# The standard error of the watchmen server
# Default is None
stderr = "$HOME/.watchmen/watchmen.stderr.log"
# The pid file of the watchmen server
# Default is `$HOME/.watchmen/watchmen.pid`
pid = "$HOME/.watchmen/watchmen.pid"
# The task config file name matching pattern
# Default is `^.*\\.(toml|ini|json)$`
mat = "^.*\\.(toml|ini|json)$"
# Tasks cache file, json format
cache = "$HOME/.watchmen/cache.json"
[sock]
# The unix socket path of the watchmen server
path = "/tmp/watchmen.sock"
[socket]
host = "127.0.0.1"
port = 1949
[http]
host = "127.0.0.1"
port = 1997
[redis]
host = "localhost"
port = 6379
username = ""
password = ""
queue_index = 0
queue_name = "watchmen"
subscribe_channels = ["watchmen"]
subscribe_name = "watchmen"watchmend
[[task]]
id = 1
name = "Async Task 1"
command = "command"
args = ["arg1", "arg2"]
dir = "/path/to/directory"
env = { key1 = "value1", key2 = "value2" }
stdin = true
stdout = "output.txt"
stderr = "error.txt"
task_type = { Async = { max_restart = 2, has_restart = 0, started_at = 0, stopped_at = 0 } }
[[task]]
id = 2
name = "Periodic Task 1"
command = "command"
args = ["arg1", "arg2"]
dir = "/path/to/directory"
env = { key1 = "value1", key2 = "value2" }
stdin = false
stdout = "output.txt"
stderr = "error.txt"
task_type = { Periodic = { started_after = 0, interval = 60, last_run = 0, sync = false } }[Async Task]
id = 1
name = Async Task 1
command = command
args = arg1 arg2
dir = /path/to/directory
env = key1=value1 key2=value2
stdin = true
stdout = "output.txt"
stderr = "error.txt"
task_type = async
max_restart = 2
[Periodic Task]
id = 2
name = Periodic Task 1
command = command
args = arg1 arg2
dir = /path/to/directory
env = key1=value1 key2=value2
stdin = false
stdout = "output.txt"
stderr = "error.txt"
task_type = periodic
started_after = 0
interval = 60
sync = false[
{
"id": 1,
"name": "Async Task 1",
"command": "command",
"args": ["arg1", "arg2"],
"dir": "/path/to/directory",
"env": {},
"stdin": true,
"stdout": "output.txt",
"stderr": "error.txt",
"created_at": 0,
"task_type": { "Async": { "max_restart": 2, "has_restart": 0, "started_at": 0, "stopped_at": 0 } }
},
{
"id": 2,
"name": "Periodic Task 1",
"command": "command",
"args": ["arg1", "arg2"],
"dir": "/path/to/directory",
"env": {},
"stdin": false,
"stdout": "output.txt",
"stderr": "error.txt",
"created_at": 0,
"task_type": { "Periodic": { "started_after": 0, "interval": 60, "last_run": 0, "sync": false } }
}
]Watchmen is a daemon process manager that for you manage and keep your application online 24/7
Usage: watchmen [OPTIONS] [COMMAND]
Commands:
run Add and run tasks
add Add tasks
reload Reload tasks
start Start tasks
restart Restart tasks
stop Stop tasks
remove Remove tasks
list Get tasks list
help Print this message or the help of the given subcommand(s)
Options:
-c, --config <CONFIG> Config file path. Default: $HOME/.watchmen/config.toml
-g, --generate <GENERATE> Generate config file
-e, --engine <ENGINE> Engine for send message [default: sock]
-v, --version Print version
-h, --help Print helpAdd and run tasks
Usage: watchmen run [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-n, --name <NAME> Task name (unique)
-c, --command <COMMAND> Task command
-a, --args <ARGS> Task arguments
-d, --dir <DIR> Task working directory
-e, --env <ENV> Task environment variables
-i, --stdin Task standard input
-o, --stdout <STDOUT> Task standard output
-w, --stderr <STDERR> Task standard error
-h, --help Print helpAdd tasks
Usage: watchmen add [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-n, --name <NAME> Task name (unique)
-c, --command <COMMAND> Task command
-a, --args <ARGS> Task arguments
-d, --dir <DIR> Task working directory
-e, --env <ENV> Task environment variables
-i, --stdin Task standard input
-o, --stdout <STDOUT> Task standard output
-w, --stderr <STDERR> Task standard error
-h, --help Print helpReload tasks
Usage: watchmen reload [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-n, --name <NAME> Task name (unique)
-c, --command <COMMAND> Task command
-a, --args <ARGS> Task arguments
-d, --dir <DIR> Task working directory
-e, --env <ENV> Task environment variables
-i, --stdin Task standard input
-o, --stdout <STDOUT> Task standard output
-w, --stderr <STDERR> Task standard error
-h, --help Print helpStart tasks
Usage: watchmen start [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpRestart tasks
Usage: watchmen restart [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpStop tasks
Usage: watchmen stop [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpRemove tasks
Usage: watchmen remove [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpPause interval tasks
Usage: watchmen pause [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpResume interval tasks
Usage: watchmen resume [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-m, --mat Is match regex pattern by namae
-h, --help Print helpGet tasks list
Usage: watchmen list [OPTIONS]
Options:
-p, --path <PATH> Task config directory
-r, --regex <REGEX> Task config filename regex pattern [default: ^.*\.(toml|ini|json)$]
-f, --config <CONFIG> Task config file
-i, --id <ID> Task id (unique)
-n, --name <NAME> Task name (unique)
-R, --mat Is match regex pattern by name
-m, --more Show more info
-l, --less Show less info
-h, --help Print help