在我的Linux服务器上,我需要同步多个脚本,用BASH和PHP编写,这样只有其中一个脚本能够启动一个系统关键的工作,这是一系列BASH / PHP命令,这些工作会搞砸由两个或多个脚本同时执行.根据我在C中使用多线程的经验,我熟悉互斥锁的概念,但是如何为在一系列不同进程中运行的脚本实现互斥锁,当然,这些脚本不是用C语言编写的?
好吧,首先想到的解决方案是确保每个脚本最初创建一个“锁定标志”文件,让其他脚本知道该作业被“锁定”,然后在完成该作业后删除该文件.但是,正如我所看到的,文件写入和读取操作必须是完全原子的才能让这种方法以100%的概率运行,并且相同的要求将适用于任何其他同步方法.而且我很确定文件写入/读取操作不是原子的,它们至少在所有现有的Linux / Unix系统中都不是原子的.
最佳答案
我不是PHP程序员,但文档说它提供了一个可以使用的便携版
flock
.第一个示例代码段看起来非常接近您想要的内容.试试这个:
PHP
$fp = fopen("/tmp/lock.txt","r+");
if (flock($fp,LOCK_EX)) { // acquire an exclusive lock
// Do your critical section here,while you hold the lock
flock($fp,LOCK_UN); // release the lock
} else {
echo "Couldn't get the lock!";
}
fclose($fp);
?>
请注意,默认情况下,flock会等到它可以获取锁定.你可以使用LOCK_EX | LOCK_NB如果要在程序的另一个副本已经运行的情况下立即退出.
使用名称“/tmp/lock.txt”可能是一个安全漏洞(我不想过于认真地决定它是否真的如此)所以你应该选择一个只能由程序写入的目录.