nanjingboy / schedule
A simple tool that provides a easy way for writing and deploying cron jobs
v0.1.0
2015-05-15 06:50 UTC
Requires
- php: >=5.4.0
- nanjingboy/commander: 0.1.0
Requires (Dev)
- phpunit/phpunit: 3.7.*
This package is not auto-updated.
Last update: 2024-10-26 18:11:55 UTC
README
Schedule:
A simple tool that provides a easy way for writing and deploying cron jobs.
Getting Started:
Here assume your application directory path is: /Users/tom/workspace/test
- cd /Users/tom/workspace/test
- Create composer.json file:
{ "require": { "php": ">=5.4.0", "nanjingboy/schedule": "*" }, "config": { "bin-dir": "bin/" } }
- Install it via composer
- bin/schedule init # Create an initial schedule.php file to define cron jobs
Example schedule.php file:
<?php use Schedule\Scheduler; $scheduler = Scheduler::instance(); $schedule->cron()->every()->months($months)->daysOfTheMonth($daysOfTheMonth)->daysOfTheWeek($daysOfTheWeek)->hours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyMinutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyHours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyDays($days)->hours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyMonths($months)->daysOfTheMonth($daysOfTheMonth)->daysOfTheWeek($daysOfTheWeek)->hours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyYear()->daysOfTheMonth($daysOfTheMonth)->daysOfTheWeek($daysOfTheWeek)->hours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyWeek()->months($months)->hours($hours)->minutes($minutes)->command($command, $options = array()); $scheduler->cron()->everyWeekday()->months($months)->hours($hours)->minutes($minutes)->command($command, $logOptions = array()); $scheduler->cron()->everyWeekend()->months($months)->hours($hours)->minutes($minutes)->command($command, $logOptions = array());
- $minutes must between 1 and 59.
- $hours must between 1 and 23.
- $daysOfTheMonth must between 1 and 30.
- $daysOfTheWeek must between 0 and 7.
- $months must between 1 and 12.
- $logOptions:
- log: output STDOUT and STDERR to the given path.
- standard_log: output STDOUT to the given path.
- error_log: output STDERR to the given path.
- if set value of log,standard_log,error_log with null, it will output STDOUT or STDERR to /dev/null.
- The value of $minutes, $hours, $daysOfTheMonth, $daysOfTheWeek, $months can be set with a single integer or array, while methods which start with every only can be set with a single integer.
- Except methods which start with every you must invoke, the other is optional.
- You can replace command method with file, get more information from file invoke.
Environment:
- If a *.env(file name will read from ENV environment) file exists in the current directory, the default environment will be read from it.
- You can also set SCHEDULE_ENV_FILE environment to special a *.env file.
- If ENV and SCHEDULE_ENV_FILE neither be set, the default environment will be read from .env file(if it exists) in the current directory.
- Get a example from: test.env
Cli:
$ bin/schedule schedule version 0.1.0 Usage: command [options] [arguments] Options: --help (-h) Display this help message --quiet (-q) Do not output any message --verbose (-v|vv|vvv) Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug --version (-V) Display this application version --ansi Force ANSI output --no-ansi Disable ANSI output --no-interaction (-n) Do not ask any interactive question Available commands: clear Clear cron jobs that defined in schedule.php file from crontab help Displays help for a command init Create an initial schedule.php file list Lists commands write Write cron jobs that defined in schedule.php file to crontab
License:
MIT