taskphp

taskPHP基于原生态php开发的定时计划任务框架,利用多进程实现任务的分配和运行,利用原生态php内存共享实现进程间通信,支持linux和windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。
PHP Other
Clone or download 
Branch:  master 
New pull request
Latest commit 96b2155 8 days ago
俞伟林
俞伟林  修改2.1 问题

 README.md

taskPHP 2.1 —— 你值得信赖的PHP定时计划任务框架

历史版本

-->taskPHP1.0

taskPHP

taskPHP基于php开发的定时计划任务框架,利用多进程实现任务的分配和运行,多种进程间通信驱动支持,支持多线程模式需要安装pthreads扩展(可选),支持linux和windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。

项目地址

github地址: https://github.com/qq8044023/taskPHP
oschina地址: http://git.oschina.net/cqcqphper/taskPHP
这两个地址都会同步更新。

在线交流QQ群

如感兴趣请加QQ群 一起探讨、完善。越多人支持,就越有动力去更新,喜欢记得右上角star哈。
taskPHP框架交流群taskPHP ①群:375841535(空)

框架概况

框架目录结构:

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

框架说明

  1. 任务多进程运行模式。
  2. 任务多线程模式,需要安装pthreads扩展(可选)。
  3. 多种进程通信方式堵塞式消息队列。
  4. 任务派发及具体任务执行不在同个进程[distribute_listen.php]和[worker_listen.php],windows和linux下启用入口文件[main.php],windows下可运行[windows_single.cmd]快速启动。
  5. 执行时间语法跟crontab类似,且支持秒设置。
   * * * * * * *    //格式 :秒 分 时 天 月 年 周
  10 * * * * * *    //表示每一分钟的第10秒运行
 /10 * * * * * *	//表示每10秒运行
 /1 * 15,16 * * * * //表示 每天的15点,16点的每一秒运行
  1. 添加任务简单,只需继承Task基类,实现任务入口run方法。

环境要求

  1. php版本>= 5.5
  2. 开启socket扩展

注意事项

  1. 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。
  2. 编写任务有问题或调用exit将导致后台脚本停止,需要通过远控管理器重启进程。
  3. 多线程模式运行一段时间后报错,pthreads has detected that the core\lib\Pthread could not be started, the system lacks the necessary resources or the system-imposed limit would be exceeded in xxx
  4. 后台任务数量多或者任务运行时间很密集导致数据库链接过多没有释放,需要再任务结尾处执行数据库链接对象的close方法来关闭链接。
  5. 在windows下路径不能有空格,否则会导致进程启动不起来。

文档列表

-->数据库类使用教程 支持(Mysql,Mongo,Oracle,Pgsql,Sqlsrv,Sqllite)
-->windows下安装php多线程扩展pthreads教程
-->工具类Utils使用说明
-->BUG记录文档

使用说明

composer安装taskphp框架:

composer require taskphp/taskphp dev-master

命令操作

main.php  start [all|任务名]  启动 可不带参数默认all
main.php  close all 结束框架  必带参数all

Windows调试启动程序

Active code page: 65001
E:\wamp\www\taskPHP>php main.php start
[16:58:00][taskPHP]:distribute start success
[16:58:00][taskPHP]:demo start success
------------------------- taskPHP ------------------------------
taskPHP version:2.0      PHP version:5.5.12
license1:https://github.com/qq8044023/taskPHP
license2:https://git.oschina.net/cqcqphper/taskPHP
startTime:2017-10-20 16:58:00
------------------------- taskPHP Manage  ----------------------
http://ServerIp:8082
http://127.0.0.1:8082
------------------------- taskPHP PROCESS ----------------------
listen                      processes                     status
distribute                    1                          [success]
demo                          1                          [success]
----------------------------------------------------------------
Press Ctrl-C to quit. Start success.

Liunx调试启动程序

[root@FX-DEBUG taskphps]# php ./main.php start
[16:58:00][taskPHP]:distribute start success
[16:58:00][taskPHP]:demo start success
------------------------- taskPHP ------------------------------
taskPHP version:2.0      PHP version:5.5.12
license1:https://github.com/qq8044023/taskPHP
license2:https://git.oschina.net/cqcqphper/taskPHP
startTime:2017-10-20 16:58:00
------------------------- taskPHP Manage  ----------------------
http://ServerIp:8082
http://127.0.0.1:8082
------------------------- taskPHP PROCESS ----------------------
listen                      processes                     status
distribute                    1                          [success]
demo                          1                          [success]
----------------------------------------------------------------
Press Ctrl-C to quit. Start success.

Liunx后台启动程序

[root@FX-DEBUG taskphps]# php ./main.php start &
[16:58:00][taskPHP]:distribute start success
[16:58:00][taskPHP]:demo start success
------------------------- taskPHP ------------------------------
taskPHP version:2.0      PHP version:5.5.12
license1:https://github.com/qq8044023/taskPHP
license2:https://git.oschina.net/cqcqphper/taskPHP
startTime:2017-10-20 16:58:00
------------------------- taskPHP Manage  ----------------------
http://ServerIp:8082
http://127.0.0.1:8082
------------------------- taskPHP PROCESS ----------------------
listen                      processes                     status
distribute                    1                          [success]
demo                          1                          [success]
----------------------------------------------------------------
Press Ctrl-C to quit. Start success.

开发者列表

内核开发

cqcqphper(小草)cqcqphper@qq.com

2.0开发者

cqcqphper(小草)cqcqphper@qq.com
村长(村长)8044023@qq.com

文档编写

hey丶(张志鸿)1270996380@qq.com

空气(空气)1925757357@qq.com

文章来源:https://github.com/qq8044023/taskPHP

taskPHP taskPHP基于php开发的定时计划任务框架,利用多进程实现任务的分配和运行,利用内存共享实现进程间通信,支持多线程模式需要安装pthreads扩展(可选),支持linux和windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。   框架概况 框架目录结构: taskPHP 根目录 |-- core 框架系统目录 | |-- lib 框架核心文件目录 | | |-- .... 众多的框架核心类库文件 | |-- guide.php 框架引导文件 | |-- distribute_listen.php 任务派发进程入口 | |-- worker_listen.php 任务执行进程入口 |-- docs 开发文档存放目录 |-- logs 日志目录 |-- tasks 用户任务目录 | |-- demo demo任务 | | |-- Lib demo任务的扩展目录 | | |-- demoTask.php demo任务类文件 | | |-- config.php demo任务配置文件 | | ... 更多任务 | |-- config.php 全局配置文件 |-- main.php 框架入口文件 |-- windows_single.cmd windows快速启动文件 框架说明 linux下子进程执行任务,修改脚本无需重启后台服务立即生效,windows下修改任务脚本后需重启后台脚本 但往系统添加执行不受影响。 框架支持多线程模式,需要安装pthreads扩展(可选)。 使用内存共享实现进程通信,堵塞式消息队列,整个框架的运行无需第三方扩展。 任务派发及具体任务执行不在同个进程[distribute_listen.php]和[worker_listen.php],windows和linux下启用入口文件[main.php],windows下可运行[windows_single.cmd]快速启动。 执行时间语法跟crontab类似,且支持秒设置。 添加任务简单,只需继承Task基类,实现任务入口run方法。 环境要求 php版本>= 5.5 开启shmop 注意事项 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。 windows下执行任务在循环里,编写任务有问题或调用exit将导致后台脚本停止,linux下无此问题。 建议生产部署在linux下运行多进程模式,因为运行在多线程模式运行一段时间后报错,pthreads has detected that the core\lib\Pthread could not be started, the system lacks the necessary resources or the system-imposed limit would be exceeded in xxx 文档列表 -->数据库类使用教程 支持(Mysql,Mongo,Oracle,Pgsql,Sqlsrv,Sqllite) -->windows下安装php多线程扩展pthreads教程 -->工具类Utils使用说明 -->http请求客户端类Client使用说明 使用说明 时间配置格式说明: * * * * * * * //格式 :秒 分 时 天 月 年 周 10 * * * * * * //表示每一分钟的第10秒运行 /10 * * * * * * //表示每10秒运行 /1 * 15,16 * * * * //表示 每天的15点,16点的每一秒运行 系统命令说明: main.php [start] 启动 可不带参数 main.php close 结束 main.php reload 重新加载任务 main.php delete demo 删除任务 main.php select 查看任务列表 main.php exec demo 运行任务 主要用于任务开发中调试单个任务 全局配置文件规范 标签:taskphp  计划任务
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值