Skip to content

Latest commit

 

History

History
96 lines (83 loc) · 4.3 KB

README.md

File metadata and controls

96 lines (83 loc) · 4.3 KB

cron(基于Swoole扩展)

1.概述

  • 基于swoole的定时器程序,支持秒级处理.
  • 异步多进程处理。
  • 完全兼容crontab语法,且支持秒的配置,可使用数组规定好精确操作时间
  • 请使用swoole扩展1.8.0-stable及以上版本.Swoole
  • 支持worker处理redis队列任务

2.配置的支持

具体配置文件请看 config/cron/crontab.php 介绍一下时间配置

0   1   2   3   4   5
|   |   |   |   |   |
|   |   |   |   |   +------ day of week (0 - 6) (Sunday=0)
|   |   |   |   +------ month (1 - 12)
|   |   |   +-------- day of month (1 - 31)
|   |   +---------- hour (0 - 23)
|   +------------ min (0 - 59)
+-------------- sec (0-59)[可省略,如果没有0位,则最小时间粒度是分钟]

3.帮助信息

* Usage: /path/to/php main.php [options] -- [args...]

* -h [--help]        显示帮助信息
* -p [--pid]         指定pid文件位置(默认pid文件保存在当前目录)
* -s start           启动进程
* -s stop            停止进程
* -s restart         重启进程
* -l [--log]         log文件夹的位置
* -c [--config]      config文件的位置
* -d [--daemon]      是否后台运行
* -r [--reload]      重新载入配置文件
* -m [--monitor]     监控进程是否在运行,如果在运行则不管,未运行则启动进程
* --worker           开启worker 可以针对redis队列读取并编写处理逻辑
* --tasktype         task任务获取类型,[file|mysql] 默认是file
* --checktime        默认精确对时(如果精确对时,程序则会延时到分钟开始0秒启动) 值为false则不精确对时

4.worker进程配置

在config/cron/worker.php 中写入配置,并且启动的时候加上 --worker选项就能启动worker工作进程 配置如下:

return [
    //key是要加载的worker类名
    "ReadBook"=>[
        "name"=>"队列1",            //备注名
        "processNum"=>1,           //启动的进程数量
        "redis"=>[
            "host"=>"127.0.0.1",    // redis ip
            "port"=>6379,           // redis端口
            "timeout"=>30,          // 链接超时时间
            "db"=>0,                // redis的db号
            "queue"=>"abc",          // redis队列名
            "limit" =>  400,          // 每次执行出队列的阀值
            "database" =>  "test_123",          // 需要初始化的db 支持多个DB test|test_123
            "param_list" =>  "logdate|pf|account|counter|kingdom|is_new|exts|serverid"         // 数据库的字段对应 解析数据 a|b|c|d 参数
        ]
    ]
];

可以通过limit参数控制每次出队列的记录数,避免高并发出队列过频繁导致mysql压力过大 。 新增数据库配置,在创建进程时候把数据库实例常驻内存 具体的业务逻辑在app/Workers/ 文件夹下。可以自己定义业务逻辑类,只需要继承library/src/Cron/Worker/Base.php中的EasyWork\Cron\Worker\Base基类就可以

5.例子

你可以在配置文件中加上以下配置:

return [
    'taskid1' =>
        [
            'taskname' => 'php -i',  //任务名称
            'rule' => '* * * * * *',//定时规则,可以使用数组精确设置时间 如:["22:18","2015-11-11 00:00:00 ","10:20:39"]
            "unique" => 2, //排他数量,如果已经有这么多任务在执行,即使到了下一次执行时间,也不执行
            'execute'  => '',//命令处理类(默认:EasyWork\Cron\Plugin\Coroutine::class)
            'args' =>
                [
                    'class' => App\Tasks\MainTask::class,//命令
                    'func' => 'test',//附加属性
                    'params' => ['a' => 'test']
                ],
        ],
];

然后去到根目录下,执行

/path/to/php start.php -s start

执行完成以后你就可以在/tmp/test.log看到输出了,每秒输出一次

如果你需要写自己的代码逻辑,你也可以到library/src/Cron/Plugin目录下,实现一个Base.php接口的类. 在其中写自己的逻辑代码。