基于PHP的定时任务管理器:Zebra-Crontab

jopen 9年前

为什么使用PHP管理crontab

一般在定时任务较少的情况下,使用原生的crontab服务一般不会有什么问题,但当定时任务较多时就会产生如下问题:

  • 文本形式的定时任务可读性很差,在没有任何注释的情况下,新人很难在不读源码的情况下了解定时任务的业务逻辑

  • 在分布式的场景中,定时任务会散落到多台机器上,无法统一管理

  • 定时任务的日志不能集中化管理,对定时任务的运行分析及故障排除比较麻烦

基于以上几点原因,我们迫切的需要一个可以集中化管理的、可配置的定时任务管理器 但自己开发一套分布式的定时任务系统何其复杂,所以作者采用crontab服务做辅助,使用php实现对定时任务的配置管理

使用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();


工具短小,但很精悍

在分布式场景中,你可以把定时任务写入数据库中进行统一管理,你可以设定哪些定时任务是由哪些机器执行, 然后通过生成文本文件的方式发送到所有机器上,再由这些机器上的phpCrontab读取处理;从而实现分布式场景下的定时任务统一管理。

项目主页:http://www.open-open.com/lib/view/home/1421553740875