php+监控任务,PHP Job任务监控

一个网站要能正常运转起来,定时任务是必不可少的。要知道定时任务程序是否正确执行,要么每天去看日志文件,要么让监控程序帮你盯着它们。

ROR的rake程序,用来调度任务脚本,可以很方便地在任务开始、结束、发生错误时插入hook,从而实现Job监控的目的。PHP没有像rake这样的程序来调度任务,所以下面自己写一个。

目录结构:

class="yaml">

jobs

|--tasks

| |-test.php

|--wake.php

其中jobs/tasks/test.php的内容如下:

print_r($argv);

?>

假设当前目录在jobs下,所有的 job 脚本存放在tasks文件夹下,如果要执行tasks/test.php,通常是这么执行的:

php tasks/test.php a b c

结果如下:

Array

(

[0] => tasks/test.php

[1] => a

[2] => b

[3] => c

)

现在我们要对这个job进行监控,需要记录它开始运行的时间,结束运行的时间,运行时发生的错误(如果有)以及抛出的异常(如果有),并且不能对现有的job脚本做太多的修改。wake.php就是本文的主角,它作为任务脚本的调度器,完成以上的需求。ROR中调度任务的程序叫rake,cakephp中console命名叫bake,我这里叫wake好了,唤醒的意思,意指唤醒具体的job。

wake.php内容:

/**

* @author lorienliu

*

* 启动Job,监控Job运行时发生的错误以及抛出的异常,记录开始和结束时间。

*/

//参数处理

array_shift($argv);

if (count($argv) == 0) {

exit;

}

$job_name = $argv[0];

$job_file_path = dirname(__FILE__) . '/tasks/' . $job_name . '.php';

// 处理错误

function error_handler($errno, $errstr, $errfile, $errline){

error_job($errno, $errstr, $errfile, $errline);

}

function start_job() {

//do something before job start

global $job_name;

echo "\n---- " . date("Y-m-d H:i:s") . " job start : " . $job_name . " ----\n";

}

//结束Job,可以在具体Job中调用,实现程序正常终止

function end_job() {

//do something after job ended

global $job_name;

echo "\n---- " . date("Y-m-d H:i:s") . " job end : " . $job_name ." ----\n";

exit;

}

function error_job($errno = 0, $errstr = '', $errfile = '', $errline = '') {

//do something when error occurs

global $job_name;

echo "\n----error occurs: ----\n";

echo "Message : $errstr\n";

echo "File : $errfile\n";

echo "Line : $errline\n\n";

exit;

}

set_error_handler('error_handler');

start_job();

try {

require_once $job_file_path;

} catch (Exception $e) {

error_job($e->getCode(), $e->getMessage(), $e->getFile(), $e->getLine());

}

end_job();

?>

使用方式如下:

php wake.php test a b c

得到以下结果,可以见到已经记录了运行时间:

---- 2013-06-08 02:36:02 job start : test ----

Array

(

[0] => test

[1] => a

[2] => b

[3] => c

)

---- 2013-06-08 02:36:02 job end : test ----

修改tasks/test.php内容,抛出异常:

print_r($argv);

throw new Exception("A custom exception");

?>

运行结果:

---- 2013-06-08 02:38:14 job start : test ----

Array

(

[0] => test

[1] => a

[2] => b

[3] => c

)

----error occurs: ----

Message : A custom exception

File : /home/gavin/www/butterfly/app/jobs/tasks/test.php

Line : 3

修改tasks/test.php内容,使得发生错误,这里引入一个不存在的文件:

print_r($argv);

require_once dirname(__FILE__) . '/abc.php';

?>

结果如下:

---- 2013-06-08 02:43:49 job start : test ----

Array

(

[0] => test

[1] => a

[2] => b

[3] => c

)

----error occurs: ----

Message : require_once(/home/gavin/www/butterfly/app/jobs/tasks/abc.php): failed to open stream: No such file or directory

File : /home/gavin/www/butterfly/app/jobs/tasks/test.php

Line : 3

可以见到,无论异常或者错误,wake.php都能够捕获。关键在于用try catch来处理异常,用set_error_handler来处理错误。这里有几个hook,start_job, end_job, error_job,可以在这些hook中添加某些操作,记录这些job的运行信息,方便统计分析。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
taskPHP taskPHP基于php开发的定时计划任务框架,利用多进程实现任务的分配和运行,利用内存共享实现进程间通信,支持多线程模式需要安装pthreads扩展(可选),支持linux和windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。   框架概况 框架目录结构: taskPHP 根目录 |-- core 框架系统目录 | |-- lib 框架核心文件目录 | | |-- .... 众多的框架核心类库文件 | |-- guide.php 框架引导文件 | |-- distribute_listen.php 任务派发进程入口 | |-- worker_listen.php 任务执行进程入口 |-- docs 开发文档存放目录 |-- logs 日志目录 |-- tasks 用户任务目录 | |-- demo demo任务 | | |-- Lib demo任务的扩展目录 | | |-- demoTask.php demo任务类文件 | | |-- config.php demo任务配置文件 | | ... 更多任务 | |-- config.php 全局配置文件 |-- main.php 框架入口文件 |-- windows_single.cmd windows快速启动文件 框架说明 linux下子进程执行任务,修改脚本无需重启后台服务立即生效,windows下修改任务脚本后需重启后台脚本 但往系统添加执行不受影响。 框架支持多线程模式,需要安装pthreads扩展(可选)。 使用内存共享实现进程通信,堵塞式消息队列,整个框架的运行无需第三方扩展。 任务派发及具体任务执行不在同个进程[distribute_listen.php]和[worker_listen.php],windows和linux下启用入口文件[main.php],windows下可运行[windows_single.cmd]快速启动。 执行时间语法跟crontab类似,且支持秒设置。 添加任务简单,只需继承Task基类,实现任务入口run方法。 环境要求 php版本>= 5.5 开启shmop 注意事项 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。 windows下执行任务在循环里,编写任务有问题或调用exit将导致后台脚本停止,linux下无此问题。 建议生产部署在linux下运行多进程模式,因为运行在多线程模式运行一段时间后报错,pthreads has detected that the core\lib\Pthread could not be started, the system lacks the necessary resources or the system-imposed limit would be exceeded in xxx 文档列表 -->数据库类使用教程 支持(Mysql,Mongo,Oracle,Pgsql,Sqlsrv,Sqllite) -->windows下安装php多线程扩展pthreads教程 -->工具类Utils使用说明 -->http请求客户端类Client使用说明 使用说明 时间配置格式说明: * * * * * * * //格式 :秒 分 时 天 月 年 周 10 * * * * * * //表示每一分钟的第10秒运行 /10 * * * * * * //表示每10秒运行 /1 * 15,16 * * * * //表示 每天的15点,16点的每一秒运行 系统命令说明: main.php [start] 启动 可不带参数 main.php close 结束 main.php reload 重新加载任务 main.php delete demo 删除任务 main.php select 查看任务列表 main.php exec demo 运行任务 主要用于任务开发中调试单个任务 全局配置文件规范 标签:taskphp  计划任务

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值