2017 © Pedro Peláez
 

library easy-task

a library for async task

image

ruziyi/easy-task

a library for async task

  • Tuesday, February 21, 2017
  • by ruziyi
  • Repository
  • 1 Watchers
  • 10 Stars
  • 27 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 4 Forks
  • 0 Open issues
  • 1 Versions
  • 17 % Grown

The README.md

EasyTask

基于swoole的任务队列, (*1)

可多进程并发执行, 主进程监听多个任务进程, 任务进程挂掉会被主进程自动拉起, (*2)

install

使用composer: composer require ruziyi/easy-task:dev-master, (*3)

手动引入: include include 'Loader.php', (*4)

example

创建task, 把要实现的业务逻辑放到run方法里, (*5)

class EchoTask extends EasyTask\Task
{
    private $msg;

    public function __construct($msg)
    {
        parent::__construct();
        $this->msg = $msg;
    }

    public function run()
    {
        echo $this->msg;
    }
}

触发任务, (*6)

$task = (new EasyTask\EchoTask("hehe\n"))->after(1000);
(new EasyTask\queue\RedisQueue)->putTask($task);

创建任务消费进程文件server.php, (*7)

$taskProcess = new EasyTask\TaskProcess();
$taskProcess->run();

启动任务消费进程, (*8)

php server.php

例子

//立即执行
$task = (new EasyTask\EchoTask("hehe\n"));
//3分钟后执行
$task = (new EasyTask\EchoTask("hehe\n"))->at(strtotime('+3 minute'));
//延迟1000ms立即执行
$task = (new EasyTask\EchoTask("hehe\n"))->after(1000);
//每1000ms执行一次, 共执行5次。不设置次数, 则一直重复执行
$task = (new EasyTask\EchoTask("hehe\n"))->every(1000, 5);
//1000ms后, 每1000ms执行一次, 共执行5次。不设置次数, 则一直重复执行
$task = (new EasyTask\EchoTask("hehe\n"))->after(1000)->every(1000, 5);

(new EasyTask\queue\RedisQueue)->putTask($task);

The Versions

21/02 2017

dev-master

9999999-dev

a library for async task

  Sources   Download

MIT

The Requires

  • php >=5.5.0

 

by Avatar ruziyi

task multi process