dragonlhp/crontab

php crontab base on pcntl and libev

1.6.3 2018-09-26 05:17 UTC

This package is auto-updated.

Last update: 2024-04-07 13:59:56 UTC


README

Total Downloads Latest Stable Version License

基于pcntl和react/event-loop的定时任务管理器

英文说明

为什么使用php_crontab?

当我们有少量的定时任务需要管理时,unix的crontab服务时足够的。如果我们有非常多的定时任务 需要管理时,机会有一些问题,例如:

  • crontab服务通过一个文本文件管理定时任务,如果没有注释,对新人来说去理解他们是比较难的。
  • 如果定时任务分散在许多机器上,管理他们也是比较难的。
  • 如果你想收集他们的日志,同样不会简单。
  • 不同用户的定时任务分散在不同的文件中。 基于以上几点原因,我们需要一个可以统一管理配置的定时任务管理器。

如何使用php_crontab?

有两种方式使用php_crontab管理你的定时任务。 你可以写一个脚本,然后把它加入到crontab服务器中,每分钟执行一次。例如tests/simple。 或者你可以写一个守护进程脚本,它会像一个服务一样一只运行,直到你杀死它。 它将每分钟检查一次定时任务。例如tests/daemon.php

特性

  • 定时任务管理可以被存储在任何地方。例如:mysql、redis等。
  • 定时任务的日志可以根据你的需要进行配置
  • 多个用户的定时任务可以统一管理
  • 多进程,每个任务一个进程
  • 你可以为每个任务设置用户和用户组
  • 标准输出可以进行重定向
  • 基于react/event-loop,它可以作为一个守护进程运行
  • 一个HTTP服务器,你可以通过它管理定时任务

HTTP 接口

HTTP 方法: GET

  • add 增加任务
  • get_by_name 根据任务名称获取任务
  • remove_by_name 根据任务名称删除任务
  • clear 删除所有任务
  • get 获取所有任务
  • start 开始检测定时任务
  • stop 停止检测定时任务

示例:

http://host:port/add?name=name&cmd=cmd&time=time&out=out&user=user&group=group&comment=comment
http://host:port/get_by_name?name=name
http://host:port/remove_by_name?name=name
http://host:port/clear
http://host:port/get
http://host:port/start
http://host:port/stop

基于crontab服务运行

* * * * * php demo.php
<?php
$missions = [
    [
        'name' => 'ls',
        'cmd' => "ls -al",
        'out' => '/tmp/php_crontab.log',
        'time' => '* * * * *',
        'user' => 'www',
        'group' => 'www'
    ],
    [
        'name' => 'hostname',
        'cmd' => "hostname",
        'out' => '/tmp/php_crontab.log',
        'time' => '* * * * *',
    ],
];

$tasks = array();
foreach($missions as $mission){
    $tasks[] = new \Jenner\Crontab\Mission($mission['name'], $mission['cmd'], $mission['time'], $mission['out']);
}

$crontab_server = new \Jenner\Crontab\Crontab(null, $tasks);
$crontab_server->start(time());

作为一个守护进程运行

it will check the task configs every minute.

$missions = [
    [
        'name' => 'ls',
        'cmd' => "ls -al",
        'out' => '/tmp/php_crontab.log',
        'time' => '* * * * *',
        'user' => 'www',
        'group' => 'www'
    ],
    [
        'name' => 'hostname',
        'cmd' => "hostname",
        'out' => '/tmp/php_crontab.log',
        'time' =>  '* * * * *',
    ],
];

$daemon = new \Jenner\Crontab\Daemon($missions);
$daemon->start();

作为守护进程运行同时启动一个http server

$missions = [
    [
        'name' => 'ls',
        'cmd' => "ls -al",
        'out' => '/tmp/php_crontab.log',
        'time' => '* * * * *',
    ],
    [
        'name' => 'hostname',
        'cmd' => "hostname",
        'out' => '/tmp/php_crontab.log',
        'time' => '* * * * *',
    ],
];

$http_daemon = new \Jenner\Crontab\HttpDaemon($missions, "php_crontab.log");
$http_daemon->start($port = 6364);

Then you can manage the crontab task by curl like:

curl http://127.0.0.1:6364/get_by_name?name=ls
curl http://127.0.0.1:6364/remove_by_name?name=hostname
curl http://127.0.0.1:6364/get

启动脚本

[root@jenner php_crontab]# ./bin/php_crontab 
php_crontab help:
-c  --config    crontab tasks config file
-p  --port      http server port
-f  --pid-file  daemon pid file
-l  --log       crontab log file
[root@jenner php_crontab]#nohup ./bin/php_crontab -c xxoo.php -p 8080 -f /var/php_crontab.pid -l /var/logs/php_crontab.log >/dev/null & 

blog:www.huyanping.cn