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

Related tags

Task Runners taskPHP
Overview

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

历史版本

-->taskPHP1.x
-->taskPHP2.x

所有分支 查看所有分支

taskPHP

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

项目地址

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

在线交流QQ群

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

框架说明

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

环境要求

  1. php版本>= 5.5
  2. 开启socket扩展
  3. 开启pdo扩展
  4. 开启shmop扩展

注意事项

  1. 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。
  2. 编写任务有问题或调用exit将导致后台脚本停止,需要通过远控管理器重启进程。
  3. 多线程模式运行一段时间后报错,pthreads has detected that the taskphp\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下代码存放路径不能有空格,否则会导致进程启动不起来。php的环境变量也最好也不要有空格,如果有空格可在框架配置中定义数组项php_path='php'。

文档列表

-->数据库类使用教程
-->windows下安装php多线程扩展pthreads教程
-->工具类Utils使用说明
-->thinkphp5.0框架的集成教程

使用说明

composer安装taskphp框架:

composer require taskphp/taskphp dev-master

命令操作

start.php  start [all|任务名]  启动 可不带参数默认all
start.php  start &   挂载后台运行,liunx操作
start.php  close all 结束框架  必带参数all

启动程序

[root@FX-DEBUG taskphps]# php ./start.php start
------------------------- taskPHP ------------------------------
taskPHP version:3.0      PHP version:5.5.38
license1:https://github.com/qq8044023/taskPHP
license2:https://gitee.com/cqcqphper/taskPHP
startTime:2018-04-04 10:00:50
------------------------- taskPHP Manage  ----------------------
http://ServerIp:8082
http://127.0.0.1:8082
------------------------- taskPHP PROCESS ----------------------
listen                      processes                     status
distribute                    1                          [success]
demo1                         1                          [success]
demo2                         1                          [success]
----------------------------------------------------------------
Press Ctrl-C to quit. Start success.
You might also like...
Comments
  • support params in callback

    support params in callback

    实际使用中存在一种场景,callback中的方法只是一个入口方法,具体执行逻辑依赖于方法的传参。 所以是否可以考虑在callback数组中增加第三个参数,用来传参,使得调度的方法更加灵活。

    Taskphp.php中这样使用:

    for($x = 0; $x < $length; $x++){
    		$v = "demo" . $x;
    		$list["task_list"][$v] = [
    				'callback'=>['app\index\command\Demo','run', $v],//任务调用:类名和方法
    				//指定任务进程最大内存  系统默认为512M
    				'worker_memory'      =>'1024M',
    				//开启任务进程的多线程模式
    				'worker_pthreads'   =>false,
    				//任务的进程数 系统默认1
    				'worker_count'=>1,
    				//crontad格式 :秒 分 时 天 月 年 周
    				'crontab'     =>'/' . (5+$x) . ' * * * * * *',
    			];
    }
    

    Demo.php中如下

    <?php
    namespace app\index\command;
    
    use taskphp\Utils;
    /**
     * 测试任务 
     */
    class Demo{
        /**
         * demo任务入口
         */
    	public static function run($a){
    	    Utils::log('demo1任务运行成功' . $a);	
    	    //可以调用thinkphp内的json函数
    	    //Utils::log(json(['message'=>'hello taskphp'])); 
    	}
    }
    
    opened by liujianhuanzz 0
  • php 低版本 语法错误

    php 低版本 语法错误

    PHP Parse error: syntax error, unexpected '[' in /data1/wwwroot/task/taskPHP-master/core/lib/App.php on line 38

    Parse error: syntax error, unexpected '[' in /data1/wwwroot/task/taskPHP-master/core/lib/App.php on line 38 PHP Parse error: syntax error, unexpected '[' in /data1/wwwroot/task/taskPHP-master/core/lib/Log.php on line 19

    Parse error: syntax error, unexpected '[' in /data1/wwwroot/task/taskPHP-master/core/lib/Log.php on line 19

    建议用 arary() 代替 [] 兼容低版本

    opened by xing2233 0
Releases(v.3.0.0)
Owner
null