首页 > 代码库 > 代码使用了php的包管理器composer,include到你的php脚本
代码使用了php的包管理器composer,include到你的php脚本
使用数据库进行crontab配置管理,除非你能够保证数据库的请求能够在长时间内保持稳定响应的话。推荐使用nosql类型的cache存储,同时做好持久化备份。
测试代码:
define(‘DS‘, DIRECTORY_SEPARATOR); requiredirname(__FILE__) . DS . ‘vendor‘. DS . ‘autoload.php‘; date_default_timezone_set(‘PRC‘); error_reporting(E_ALL); $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();
这段代码使用了php的包管理器composer,如果你不了解,可以手动把需要用到的类,include到你的php脚本。
运行后,我们会在默认的日志文件(/var/log/php_crontab.log)中查看crontab的运行记录,当然你可以通过向Crontab传递第二个参数指定日志文件日志(确保可写)。日志文件内容如下:
[2014-11-10 19:50:08]-content:start. pid3778 [2014-11-10 19:50:08]-content:php -v [2014-11-10 19:50:08]-content:php -i [2014-11-10 19:50:08]-content:php -i [2014-11-10 19:50:082881064151]-content:end. pid:3778
日志会记录程序的启动时间、运行的命令、pid等信息。由于我是手动执行的,所以描述不是准确的00秒。正式使用时,在crontab中添加一条如下命令即可实现该管理器的自动运行。
* * * * * php php_crontab_manager.php
管理器相关依赖: 进程控制包:"jenner/multi_process": "1.0.0", pcntl扩展 crontab服务
jenner/multi_process包是一个简单的进程控制包,主要是为了在执行定时任务时,使用子进程执行,这样父进程就不会阻塞,造成定时任务延迟的问题。
项目地址:
这个项目托管在github上,同时提供了packagist包支持,你可以通过在composer.json中添加:"jenner/crontab": "1.0.0"来载入这个包。
具体源码可以在github查看。
原创文章,转载请注明: 转载自始终不够
本文链接地址: 基于PHP的crontab定时任务管理
代码使用了php的包管理器composer,include到你的php脚本