一个简化进程管理的 Python
库,丰富的命令行控制参数满足各种运行需求
仅支持 Linux/Unix
- 需要不影响业务(一致性)的情况下管理进程,比如 stop/reload/restart
- 需要
nohup
、screen
等运行 - 需要驻留后台
极少代码侵入,即可达到优雅的停止、重载(重启),不需要 kill -9
强制杀死进程,不影响业务数据处理或写入,也可以直接使用sppm_cli将Shell命令封装成服务进程。__
pip install sppm
usage: /usr/bin/sppm_cli --no-daemon -v -l --name progress_name [--start|--stop|--reload|--shutdown|--restart|--status] [shell]
Sample Python Process Manager 客户端,直接将Shell命令转换为可管理的服务进程,方便管理。比如管理SpringBoot程序
positional arguments:
shell 执行的Shell命令,配合 --start 或 --restart 参数使用
options:
-h, --help show this help message and exit
--no-daemon 不使用进程管理模式
-l {0,1,2,3,4,5}, --log-level {0,1,2,3,4,5}
日志级别,0(CRITICAL)、1(ERROR)、2(WARNING)、3(INFO)、4(DEBUG)、5(TRACE),默认等级3
--start 启动子进程
--stop 等待子进程正常退出
--reload 等待子进程正常退出,并启动新的子进程
--shutdown 强制杀掉子进程
--restart 强制杀掉子进程,并启动新的子进程
--status 显示子进程状态
-v, --version 显示版本信息
--name NAME 显示的进程名称,仅支持字母、数字和下划线组成的字符串
--user USER 指定运行Shell命令的用户,配合 --start 或 --restart 参数使用
sppm_cli --name foo '/usr/bin/python -m http.server' --start --user $USER
sppm_cli --name foo --status
pid : 237764
ppid : 237763
alive : true
uptime : 23 second(s)
human readable uptime: 23 second(s)
create time : 2022-06-17 17:58:42.470000
active : false
last active time : 2022-06-17 17:58:43.300041
sppm_cli --name foo '/usr/bin/python -m http.server' --restart --user $USER
sppm_cli --name foo --stop
usage: examples/example.py --no-daemon -v -l [--start|--stop|--reload|--shutdown|--restart|--status]
简化进程管理的命令行工具
optional arguments:
-h, --help show this help message and exit
--no-daemon 不使用进程管理模式
-l {0,1,2,3,4,5}, --log-level {0,1,2,3,4,5}
日志级别,0(CRITICAL)、1(ERROR)、2(WARNING)、3(INFO)、4(DEBUG)、5(TRACE),默认等级3
--start 启动子进程
--stop 等待子进程正常退出
--reload 等待子进程正常退出,并启动新的子进程
--shutdown 强制杀掉子进程
--restart 强制杀掉子进程,并启动新的子进程
--status 显示子进程状态
-v, --version 显示版本信息
import sppm
sppm.sppm_start(foo)
更多细节,请查看 examples/example.py
以及 examples/example_working_lock.py
更多使用方法,请执行 python3 examples/example.py -h
查看帮助信息。
python3 examples/example.py --start
2019-12-01 17:45:07 15048 [INFO] **** 按Ctrl+C可以终止运行 ****
2019-12-01 17:45:07 15049 [INFO] Run 0 time(s) task->foo.
2019-12-01 17:45:17 15049 [INFO] Run 1 time(s) task->foo.
2019-12-01 17:45:27 15049 [INFO] Run 2 time(s) task->foo.
2019-12-01 17:45:37 15049 [INFO] Run 3 time(s) task->foo.
^C2019-12-01 17:45:47 15049 [INFO] Run 4 time(s) task->foo.
执行exit_callback函数
指定日志等级:
python3 examples/example.py --start -l 5
python3 examples/example.py --status
pid : 16728
ppid : 16727
alive : true
uptime : 152 second(s)
human readable uptime: 2 minute(s), 32 second(s)
create time : 2019-12-01 18:32:30.300000
active : false
last active time : 2019-12-01 18:32:30.696024
python3 examples/example.py --stop
python3 examples/example.py --start
SPPM_ENV=examples/.sppm_env_working_lock python examples/example_working_lock.py --start
$ python3 examples/example.py --status
pid : 17404
ppid : 17403
alive : true
uptime : 48 second(s)
human readable uptime: 48 second(s)
create time : 2019-12-01 18:49:47.880000
active : false
last active time : 2019-12-01 18:49:48.273476
$ SPPM_ENV=examples/.sppm_env_working_lock python examples/example_working_lock.py --status
pid : 17397
ppid : 17396
alive : true
uptime : 40 second(s)
human readable uptime: 40 second(s)
create time : 2019-12-01 18:49:25.690000
active : true
last active time : 2019-12-01 18:50:06.127305
默认情况下,程序自动从环境变量 SPPM_ENV
加载 Python
文件目录下的 .sppm_env
。
$ cat examples/.sppm_env
pid=/tmp/example.pid
child_pid=/tmp/example_child.pid
lock=/tmp/example.lock
log=/tmp/example.log
运行多个程序时,每个程序必须单独配置环境变量 SPPM_ENV
指向不同的配置文件。
--user USER 指定运行Shell命令的用户,配合 --start 和 --restart 参数使用