一般在定时任务较少的情况下,使用原生的crontab服务一般不会有什么问题,但当定时任务较多时就会产生如下问题:
文本形式的定时任务可读性很差,在没有任何注释的情况下,新人很难在不读源码的情况下了解定时任务的业务逻辑
在分布式的场景中,定时任务会散落到多台机器上,无法统一管理
定时任务的日志不能集中化管理,对定时任务的运行分析及故障排除比较麻烦
基于以上几点原因,我们迫切的需要一个可以集中化管理的、可配置的定时任务管理器 但自己开发一套分布式的定时任务系统何其复杂,所以作者采用crontab服务做辅助,使用php实现对定时任务的配置管理
Crontab/blob/master/README.md#%E4%BD%BF%E7%94%A8php%E7%AE%A1%E7%90%86%E5%AE%9A%E6%97%B6%E4%BB%BB%E5%8A%A1%E6%9C%89%E5%93%AA%E4%BA%9B%E4%BC%98%E5%8A%BF)使用php管理定时任务有哪些优势
定时任务可以不再是以文本方式的形式存在,可以存储在缓冲、数据库中,甚至你可以开发管理功能,在后台对定时任务进行编辑
定时任务的日志是可配置的,你可以按照业务需求,对日志进行差异化配置
使用方式如下:
编写一个任务管理器,可参考test/simple.php
将上述脚本添加到crontab中,一分钟执行一次
示例:
<?php $crontab_config = [ 'test_1' => [ 'name' => '服务监控1', 'cmd' => 'php -v', 'output' => '/tmp/test.log', 'time' => '* * * * *' ], 'single_test' => [ 'name' => 'php -i', 'cmd' => 'php -i', 'output' => '/tmp/single_script.log', 'time' => [ '* * * * *', '* * * * *', ], ], ]; $crontab_server = new \Jenner\Zebra\Crontab\Crontab($crontab_config); $crontab_server->start();
Crontab/blob/master/README.md#%E5%B7%A5%E5%85%B7%E7%9F%AD%E5%B0%8F%E4%BD%86%E5%BE%88%E7%B2%BE%E6%82%8D)工具短小,但很精悍
在分布式场景中,你可以把定时任务写入数据库中进行统一管理,你可以设定哪些定时任务是由哪些机器执行, 然后通过生成文本文件的方式发送到所有机器上,再由这些机器上的phpCrontab读取处理;从而实现分布式场景下的定时任务统一管理。