利用flock解决一个进程多次运行的问题

Posted by Remilia Scarlet on July 17, 2019

利用 linux flock 锁机制

利用 flock(FreeBSD lockf,CentOS下为 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: 显示版本

锁类型:

共享锁:多个进程可以使用同一把锁,常被用作读共享锁
独占锁:同时只允许一个进程使用,又称排他锁,写锁。

这里我们需要同时只允许一个进程使用,所以使用独占锁。

flock -xn /tmp/test.lock -c ‘./test.sh’


| 访问量: