# timerTask.php
定时Task/定时Model配置文件
使用task_name将会调用Task,使用model_name将会调用Model,Task是同步阻塞,Model是异步非阻塞,如果是长时间耗时任务建议用Task。
```php
/**
* timerTask定时任务
* (选填)task名称 task_name
* (选填)model名称 model_name task或者model必须有一个优先匹配task
* (必填)执行task的方法 method_name
* (选填)执行开始时间 start_time,end_time) 格式: Y-m-d H:i:s 没有代表一直执行,一旦end_time设置后会进入1天一轮回的模式
* (必填)执行间隔 interval_time 单位: 秒
* (选填)最大执行次数 max_exec,默认不限次数
* (选填)是否立即执行 delay,默认为false立即执行
*/
$config['timerTask'] = [];
//下面例子表示在每天的14点到20点间每隔1秒执行一次
/*$config['timerTask'][] = [
'start_time' => 'Y-m-d 19:00:00',
'end_time' => 'Y-m-d 20:00:00',
'task_name' => 'TestTask',
'method_name' => 'test',
'interval_time' => '1',
];*/
//下面例子表示在每天的14点到15点间每隔1秒执行一次,一共执行5次
/*$config['timerTask'][] = [
'start_time' => 'Y-m-d 14:00:00',
'end_time' => 'Y-m-d 15:00:00',
'task_name' => 'TestTask',
'method_name' => 'test',
'interval_time' => '1',
'max_exec' => 5,
];*/
//下面例子表示在每天的0点执行1次(间隔86400秒为1天)
/*$config['timerTask'][] = [
'start_time' => 'Y-m-d 23:59:59',
'task_name' => 'TestTask',
'method_name' => 'test',
'interval_time' => '86400',
];*/
//下面例子表示在每天的0点执行1次
/*$config['timerTask'][] = [
'start_time' => 'Y-m-d 14:53:10',
'end_time' => 'Y-m-d 14:54:11',
'task_name' => 'TestTask',
'method_name' => 'test',
'interval_time' => '1',
'max_exec' => 1,
];*/
return $config;
```
>如果开启了Consul可以通过Consul的KV来动态修改和删除添加定时任务。
>使用Task有很多限制,如果是长耗时任务可以使用自定义进程,通过TimerTask.php配置调用Model,在Model里面通过进程间通讯API调用自定义进程
- SD3.X简介
- 捐赠SD项目
- VIP服务
- 基础篇
- 搭建环境
- 使用Composer安装/更新SD框架
- 启动命令
- 开发注意事项
- 框架配置
- 配置文件夹
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定义配置
- 框架入口
- MVC架构
- 加载器-Loader
- 控制器-Controller
- 模型-Model
- 视图-View
- 同步任务-Task
- 封装器
- Swoole编程指南-EOF协议
- Swoole编程指南-固定包头协议
- 封装器-Pack
- 路由器
- TCP相关
- 绑定UID
- Send系列
- Sub/Pub
- 获取服务器信息
- Http相关
- HttpInput
- HttpOutput
- 默认路由规则
- WebSocket相关
- 使用SSL
- 公共函数
- 进阶篇
- 内核优化
- 封装器路由器原理剖析
- 对象池
- 上下文-Context
- 中间件
- 进程管理
- 创建自定义进程
- 进程间RPC
- 自定义进程如何使用连接池
- 异步连接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服务-Consul
- Consul基础
- 搭建Consul服务器
- SD中Consul配置
- 微服务
- 选举-Leader
- Consul动态配置定时任务
- 熔断与降级
- 集群-Cluster
- 高速缓存-CatCache
- 万物-Actor
- Actor原型
- Actor的创建
- Actor间的通讯
- 消息派发-EventDispatcher
- 延迟队列-TimerCallBack
- 协程
- 订阅与发布
- MQTT简易服务器
- AMQP异步任务调度
- 自定义命令-Console
- 调试工具Channel
- 特别注意事项
- 日常问题总结
- 实践案例
- 物联网自定义协议
- Actor在游戏的应用
- Mongodb以及一些同步扩展的使用
- 自定义进程使用MQTT客户端
- 开发者工具
- SDHelper