cknit高可用定时多任务管理工具
cknit
cknit 是一款开源高可用定时多任务管理工具,定时精度为秒级别,能够确保高效、稳定的处理多任务。 定时精度随任务量的变化如下所示 ( 测试平台OSX ):
任务数量 | 定时精度偏差 |
---|---|
1000 | 0.01s |
100000 | 1s |
支持平台
目前支持 Linux、mac 两大平台,mac 平台使用 select 系统调用,Linux平台使用 Posix (timer),因此 Linux 平台性能比 mac 平台稍高,任务调度精度更佳
时间间隔格式
标准格式:
* * * * * * *
列 | 含义 | 取值范围 |
---|---|---|
1 | 秒 | 0-60 |
2 | 分 | 0-59 |
3 | 时 | 0-23 |
4 | 日 | 1-31 |
5 | 月 | 0-11 0:表示一月 |
6 | 周 | 0-6 0: 表示周日 |
设计架构
安装
**cknit **采用 cmake 编译系统,因此需要目标机器安装 cmake 3.13 及以上版本
1、下载源码
git clone https://gitee.com/josinli/cknit.git
2、编译
mkdir build cd build cmake .. make && make install cknit
APIs管理
安装完成后,访问:
http://127.0.0.1:9898
响应如下:
{ "message": "Welcome use cknit", "code": "ok", "version": "1.0", "port": 9898, "APIs": [ { "name": "Get all monitors tasks", "method": "GET", "protocol": "HTTP/1.1", "url": "http://127.0.0.1:9898/monitors" }, { "name": "Add one monitors tasks", "method": "POST", "protocol": "HTTP/1.1", "url": "http://localhost:9898/monitors" }, { "name": "Modify one monitors tasks", "method": "PUT", "protocol": "HTTP/1.1", "url": "http://localhost:9898/monitors" } ] }
API: 获取当前所有的任务
GET http://127.0.0.1:9898/monitors
响应回答如下:
[ { "command": "php ~/Desktop/index.php", "period": "* 1,2,3,10-20 * * * *", "id": 1, "status": 0 }, { "command": "php ~/Desktop/index.phpd", "period": "* * * * * * */2" } ]
API: 在线添加任务
POST http://127.0.0.1:9898/monitors { "command": "php ~/Desktop/index.php", "period": "* * * * * * */2" }
响应回答如下:
{ "message": "Success", "code": "true", "operation": "Add task" }
API: 在线修改已存任务(id是系统自动分配的)
PUT http://127.0.0.1:9898/monitors { "id": 998, "data": { "status":0, "period": "* * * 11 * */2", } }
响应回答如下:
{ "message": "Success", "code": "true", "operation": "Modify task" }
评论