在posix系统上,查询pid是否正在运行的典型方法是向其发送空信号,例如
kill(pid,0)。如果调用成功,则存在该过程;如果返回
ESRCH,则不返回。这自然会遇到不可避免的种族条件,这实际上比理论上要少得多。不太统一的方法是读取/
proc文件系统(如果操作系统具有该文件系统),这会花费更多的精力,相当于同一件事,并且仍然受相同的竞争条件的影响。
请注意,pid锁定文件技术可以分为两层。也就是说,正在运行的进程将创建文件,将其锁定并写入其pid。它在运行期间保持锁定,因此这几乎不需要上面查询进程是否正在运行的原因,因为如果进程崩溃,即使文件仍然存在,文件锁也会自动释放。逻辑如下:
if file exists if can get lock prev instance died unnaturally continue with this new process else instance already runningelse good to go, continue with new process
此技术还具有比赛条件。
我不记得有足够的Java来说它是否具有包装器
kill或文件锁定系统调用(如)
flock,
lockf并且是否
fcntl需要实施此方案。



