这个方案目前已经是比较成熟,主要是结合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'
每天进步一点点,更多精彩内容,欢迎关注公众号“编程社”!!!