taskPHP - 定时计划任务框架


GPL
跨平台
PHP

软件简介

taskPHP 基于原生态 php 开发的定时计划任务框架,利用多进程实现任务的分配和运行,利用原生态php内存共享实现进程间通信,支持 linux 和
windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。

框架概况

taskPHP                             根目录
|-- core                            框架系统目录
|   |-- lib                         框架核心文件目录
|   |   |-- ....                    众多的框架核心类库文件
|   |-- guide.php                   框架引导文件
|   |-- distribute_listen.php       任务派发进程入口
|   |-- worker_listen.php           任务执行进程入口
|-- logs                            日志目录
|-- tasks                           用户任务目录
|   |-- demo                        demo任务
|   |   |-- Lib                     demo任务的扩展目录
|   |   |-- demoTask.php            demo任务类文件
|   |   |-- config.php              demo任务配置文件
|   |   ...                         更多任务
|   |-- config.php                  全局配置文件
|-- main.php                        框架入口文件
|-- windows_single.cmd              windows快速启动文件

框架说明

  1. linux下子进程执行任务,修改脚本无需重启后台服务立即生效,windows下修改任务脚本后需重启后台脚本 但往系统添加执行不受影响

  2. 使用内存共享实现进程通信,堵塞式消息队列,整个框架的运行无需第三方扩展。

  3. 任务派发及具体任务执行不在同个进程[distribute_listen.php]和[worker_listen.php],windows和linux下启用入口文件[main.php],windows下可运行[windows_single.cmd]快速启动

  4. 执行时间语法跟crontab类似实现crontab的运行规则,并有辅助工具在Utils类,且支持秒设置.

  5. 添加任务简单,只需继承Task基类,实现任务入口run方法

注意事项

  1. 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。

  2. windows下执行任务在循环里,编写任务有问题或调用exit将导致后台脚本停止,linux下无此问题。

使用说明

系统命令说明:

mian.php start  启动
mian.php close  结束
main.php  reload  重新加载任务
main.php  delete demo   删除任务
main.php  select  查看任务列表