基于 webman + TP-ORM 的动态秒级定时任务管理,兼容 Windows 和 Linux 系统。
基于原作者项目更改的部分适合自己使用的模块插件
原项目地址:https://github.com/yzh52521/webman-task
喜欢原版的请移步原作者
【原旧版本->改动】
- 修改创建数据库时候的部分字段未设置默认值的bug
- 更改必须使用execute方法,可以使用自定义方法【自定义方法请写到:target 后面,例如:app\common\crontab\ClearLogCrontab\test】
- 修复禁用、暂停、在下一分钟才生效的bug
- 新增任务日志设置项
- 插件默认关闭状态,如需启动,请在配置文件中修改enable=true
- windows用户 启动webman 使用 windows.php
- 使用前请先确认是否composer已安装以下3个插件:
- workerman/crontab
- webman/think-orm
- guzzlehttp/guzzle
composer require xianrenqh/webman-crontab-task
0 1 2 3 4 5
| | | | | |
| | | | | +------ day of week (0 - 6) (Sunday=0)
| | | | +------ month (1 - 12)
| | | +-------- day of month (1 - 31)
| | +---------- hour (0 - 23)
| +------------ min (0 - 59)
+-------------- sec (0-59)[可省略,如果没有0位,则最小时间粒度是分钟]
$param = [
'method' => 'crontabIndex',//计划任务列表
'args' => ['limit' => 10, 'page' => 1]//参数
];
$result= xianrenqh\Task\Client::instance()->request($param);
return json($result);
-
url 任务可以指定一个url地址来请求,没有什么可解释的。
-
eval 任务可以直接写入 php 代码,但代码请不要带 ,具体查阅 eval 函数
-
Class 任务必须指定带有 命名空间的类名,并且实现一个 public 属性的方法:方法返回值为 bool / string 类型
-
Command 任务请先按照 webman 官方文档定义好执行命令,在新增任务,输入定义的 命令 即可 例如:php webman version 或者 version
-
Shell 任务 在新增任务,输入定义的 shell命令 即可 例如:ps -ef | grep php
method: crontabIndex
args
参数名称 | 是否必须 | 示例 | 备注 |
---|---|---|---|
page | 是 | 1 | 页码 |
limit | 是 | 15 | 每页条数 |
{
"code": 200,
"msg": "ok",
"data": {
"total": 4,
"per_page": 15,
"current_page": 1,
"last_page": 1,
"data": [
{
"id": 6,
"title": "class任务 每月1号清理所有日志",
"type": 2,
"rule": "0 0 1 * *",
"target": "app\\api\\controller\\testController\\test",
"parameter": "",
"running_times": 71,
"last_running_time": 1651121710,
"remark": "",
"sort": 0,
"status": 1,
"create_time": 1651114277,
"update_time": 1651114277,
"singleton": 1
},
{
"id": 5,
"title": "eavl任务 输出 hello world",
"type": 4,
"rule": "* * * * *",
"target": "echo 'hello world';",
"parameter": "",
"running_times": 25,
"last_running_time": 1651121701,
"remark": "",
"sort": 0,
"status": 1,
"create_time": 1651113561,
"update_time": 1651113561,
"singleton": 0
},
{
"id": 3,
"title": "url任务 打开 workerman 网站",
"type": 3,
"rule": "*/20 * * * * *",
"target": "https://www.workerman.net/",
"parameter": "",
"running_times": 39,
"last_running_time": 1651121700,
"remark": "请求workerman网站",
"sort": 0,
"status": 1,
"create_time": 1651112925,
"update_time": 1651112925,
"singleton": 0
},
{
"id": 1,
"title": "command任务 输出 webman 版本",
"type": 1,
"rule": "*/20 * * * * *",
"target": "version",
"parameter": null,
"running_times": 112,
"last_running_time": 1651121700,
"remark": "20秒",
"sort": 0,
"status": 1,
"create_time": 1651047480,
"update_time": 1651047480,
"singleton": 1
}
]
}
}
method: crontabLog
args
参数名称 | 是否必须 | 示例 | 备注 |
---|---|---|---|
page | 是 | 1 | 页码 |
limit | 是 | 15 | 每页条数 |
crontab_id | 否 | 1 | 计划任务ID |
{
"code": 200,
"msg": "ok",
"data": {
"total": 97,
"per_page": 15,
"current_page": 1,
"last_page": 7,
"data": [
{
"id": 257,
"crontab_id": 1,
"target": "version",
"parameter": "",
"exception": "Webman-framework v1.3.11",
"return_code": 0,
"running_time": "0.834571",
"create_time": 1651123800,
"update_time": 1651123800
},
{
"id": 251,
"crontab_id": 1,
"target": "php webman version",
"parameter": "",
"exception": "Webman-framework v1.3.11",
"return_code": 0,
"running_time": "0.540384",
"create_time": 1651121700,
"update_time": 1651121700
},
{
"id": 246,
"crontab_id": 1,
"target": "php webman version",
"parameter": "{}",
"exception": "Webman-framework v1.3.11",
"return_code": 0,
"running_time": "0.316019",
"create_time": 1651121640,
"update_time": 1651121640
},
{
"id": 244,
"crontab_id": 1,
"target": "php webman version",
"parameter": "{}",
"exception": "Webman-framework v1.3.11",
"return_code": 0,
"running_time": "0.493848",
"create_time": 1651121580,
"update_time": 1651121580
}
]
}
}
method: crontabCreate
args
参数名称 | 参数类型 | 是否必须 | 示例 | 备注 |
---|---|---|---|---|
title | text | 是 | 输出 webman 版本 | 任务标题 |
type | text | 是 | 1 | 任务类型 (1 command, 2 class, 3 url, 4 eval ,5 shell) |
rule | text | 是 | */3 * * * * * | 任务执行表达式 |
target | text | 是 | php webman version/ version | 调用任务字符串 |
parameter | text | 否 | {} | 调用任务参数(url和eval无效) |
remark | text | 是 | 每3秒执行 | 备注 |
sort | text | 是 | 0 | 排序 |
status | text | 是 | 1 | 状态[0禁用; 1启用] |
singleton | text | 否 | 1 | 是否单次执行 [0 是 1 不是] |
{
"code": 200,
"msg": "ok",
"data": {
}
}
method: crontabReload
args
参数名称 | 参数类型 | 是否必须 | 示例 | 备注 |
---|---|---|---|---|
id | text | 是 | 1,2 | 计划任务ID 多个逗号隔开 |
{
"code": 200,
"msg": "ok",
"data": {
}
}
method: crontabUpdate
args
参数名称 | 参数类型 | 是否必须 | 示例 | 备注 |
---|---|---|---|---|
id | text | 是 | 1 | |
title | text | 否 | 输出 webman 版本 | 任务标题 |
type | text | 否 | 1 | 任务类型 (1 command, 2 class, 3 url, 4 eval,5 shell) |
rule | text | 否 | */3 * * * * * | 任务执行表达式 |
target | text | 否 | php webman version/version | 调用任务字符串 |
parameter | text | 否 | {} | 调用任务参数(url和eval无效) |
remark | text | 否 | 每3秒执行 | 备注 |
sort | text | 否 | 0 | 排序 |
status | text | 否 | 1 | 状态[0禁用; 1启用] |
singleton | text | 否 | 1 | 是否单次执行 [0 是 1 不是] |
//使用类【type=2】的添加案例
$request = [
'method' => 'crontabCreate',
'args' => [
'title' => '检测设备心跳',
'type' => 2,
'rule' => '*/3 * * * * *',
'target' => 'app\api\crontab\HeartCrontab\checkheart',
'status' => 1,
'remark' => '每3秒执行',
]
];
$result = \xianrenqh\Task\Client::instance()->request($request);
return json($result);
{
"code": 200,
"msg": "ok",
"data": {
}
}
method: crontabDelete
args
参数名称 | 参数类型 | 是否必须 | 示例 | 备注 |
---|---|---|---|---|
id | text | 是 | 1,2 | 计划任务ID 多个逗号隔开 |
{
"code": 200,
"msg": "ok",
"data": {
}
}