Linux下面Crontab文件锁实现进程互斥

这个方案目前已经是比较成熟,主要是结合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:显示版本。

具体实现

如下面的实例,原计划每5秒执行一次test脚本,同时产生test.lock文件,如果5秒时间前一个进程没有执行完,后面一个进程发起了,便会放弃本次操作。

*/5 * * * * flock -x -n /tmp/test.lock -c '/test.sh'

每天进步一点点,更多精彩内容,欢迎关注公众号“编程社”!!!
在这里插入图片描述

posted on 2019-08-11 22:37  黑夜开发者  阅读(25)  评论(0编辑  收藏  举报