Beefy Boxes and Bandwidth Generously Provided by pair Networks
No such thing as a small change

Re: Ensuring only one copy of a perl script is running at a time

by Skeeve (Vicar)
on Dec 19, 2006 at 16:28 UTC ( #590695=note: print w/replies, xml ) Need Help??

in reply to Ensuring only one copy of a perl script is running at a time

If I can't use flock or a module, I usually go to create a "Semaphore" file, meaning, I define a filename and location and create a 0 byte file there. When the program starts, it tries to rename the file to some temporary name. If this succeeds, the program may run. If not, I retry or bail out.

the file has to be re-renamed when the program is done.

this algorithm assumes that file renaming is an atomic process, meaning that it can't be interrupted by the system and that a program, which renamed the file, really did so.


Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://590695]
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others studying the Monastery: (3)
As of 2018-02-22 03:36 GMT
Find Nodes?
    Voting Booth?
    When it is dark outside I am happiest to see ...

    Results (288 votes). Check out past polls.