cknit高可用定时多任务管理工具

联合创作 · 2023-09-29 14:44

cknit


cknit 是一款开源高可用定时多任务管理工具,定时精度为秒级别,能够确保高效、稳定的处理多任务。 定时精度随任务量的变化如下所示 ( 测试平台OSX ):



















任务数量 定时精度偏差
1000 0.01s
100000 1s

支持平台


目前支持 Linuxmac 两大平台,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


安装


**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"
}
浏览 24
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报