关于php cron任务管理的实现假设

以前每开发一个计划任务功能均须要在线上操做crontab来新增项,因此想采用PHP来统一管理单个项目中的任务项,
能够经过创建表[id,name,status,func,timer,last_time,created_at] 来统一存放项目中的计划任务脚本,经过简单的配置
能将各计划任务抽象成简单的任务类,而后经过crontab中配置的单个入口对其进行统一访问,从而减小了上线代码对
线上服务器环境进行修改的麻烦.

而后此处有一些坑,由于任务按功能性质划分可能有好几种,好比:

1. 单次执行,马上结束,同一时刻可运行多个实例
2. 守护进程,同一时刻只能运行一个实例

对 第二种 须要 加锁 机制,还要防止程序由于出现爆错,异常等状况没有解锁,致使不能再次启动此种任务
对于此种任务还须要考虑运行期间若是因其余需求变动,如何快速方便的终止此任务

猜测 经过 任务id  来实现锁机制,每次任务执行时均须要申请锁,每次申请的锁均有固定的使用配额,此种任务
每批次执行完成后均需消耗一次使用配额,当配额为0时则须要向系统从新申请锁.

lock_id: $task_id
lock_{$task_id}_quota: $quota 

每次从新申请锁,均需再次读取任务配置表中该任务的配置信息

若是申请失败(-1),则关闭这次执行,等待下次执行. 这样当想停止此种任务时可采起2种方案:
1. 停止本次,只需将其使用配额设为-1
2. 彻底禁止,重置本任务的status为禁用,再重置其使用配额为-1

任务结束以后,要释放锁,若是锁释放失败,须要有一个 无效锁检测机制来强制释放

无效锁的断定:
关键是 如何肯定 任务实例是不是活着的,锁配额 < 1 可否认定是无效锁.会不会出现任务在从新申请锁的过程当中
被 无效锁检测机制给干掉?

干掉以后是否有影响?

-------------- 服务器

以上是个人假想,求拍砖 进程

相关文章
相关标签/搜索