当前项目已经有一个更好的实现:
Croon - https://github.com/hfcorriez/croon
该项目将会停止更新!请使用实现更完善的croon
0.1
实现crontab基本功能,实现秒级控制,记录日志和内存占用0.2
优化和改进,分离配置使可以单独配置文件路径,日志等0.3
按照PSR重构,支持文件和数据库模式0.4
支持结果上报,可以上报到数据库或者文件0.5
支持目前了解的所有格式,优化配置格式,支持关闭logger和reporter
- 语法和crontab相同
- 精确到秒级的控制
- 每个任务都使用独立进程
- 支持PSR标准
- 支持文件
- 支持数据库
基于PHP实现的CRONTAB,可以精确到秒级的执行过程,完全兼容Linux系统的crontab写法。
About Crontab... crontab.org
git clone git://github.com/hfcorriez/php-crontab.git
cd php-crontab
复制配置
cp bin/crontab.ini.example bin/crontab.ini
修改配置
bin/crontab.ini:
[crontab]
crontab.adapter = adapter
crontab.reporter = reporter
crontab.logger = logger
crontab.timeout = 600
[adapter]
adapter.mode = file
adapter.path = tasks
[reporter]
reporter.mode = file
reporter.path = report.log
[adapter1]
adapter1.mode = database
adapter1.dsn = "mysql:host=localhost;port=3306;dbname=dbname;charset=UTF8"
adapter1.username = username
adapter1.password = password
adapter1.table = command
adapter1.field = command
[reporter1]
reporter1.mode = database
reporter1.dsn = "mysql:host=localhost;port=3306;dbname=dbname;charset=UTF8"
reporter1.username = username
reporter1.password = password
reporter1.table = report
[logger]
logger.mode = file
logger.path = crontab.log
运行例子
cp bin/tasks.example bin/tasks
chmod +x bin/crontab
./bin/crontab --master
从0.4开始支持结果上报,有File和Database两种模式。 在0.3也支持任务列表从数据库中读取
MySQL可以从 readme/crontab.sql 导入