转载:https://blog.csdn.net/fdipzone/article/details/38284009
问题:
对于定时任务,如果任务周期小于任务执行时长,如何保证单个任务执行?
比如任务A完成一次执行需要10分钟,任务A的定时计划为每分钟执行一次,如何保证只有一个任务A在执行?
答案:使用文件锁
使用linux flock 文件锁实现任务锁定,解决冲突
格式: flock [-sxun][-w #] fd# flock [-sxon][-w #] file [-c] command 选项 -s, --shared: 获得一个共享锁 -x, --exclusive: 获得一个独占锁 -u, --unlock: 移除一个锁,通常是不需要的,脚本执行完会自动丢弃锁 -n, --nonblock: 如果没有立即获得锁,直接失败而不是等待 -w, --timeout: 如果没有立即获得锁,等待指定时间 -o, --close: 在运行命令前关闭文件的描述符号。用于如果命令产生子进程时会不受锁的管控 -c, --command: 在shell中运行一个单独的命令 -h, --help 显示帮助 -V, --version: 显示版本
继续用回第一个test.php,文件锁使用独占锁,如果锁定则失败不等待。参数为-xn
* * * * * flock -xn /tmp/mytest.lock -c 'php /home/fdipzone/php/test.php >> /home/fdipzone/php/test.log'
这样当任务未执行完成,下一任务判断到/tmp/mytest.lock被锁定,则结束当前的任务,下一周期再判断。