Beefy Boxes and Bandwidth Generously Provided by pair Networks
Clear questions and runnable code
get the best and fastest answer

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 making s'mores by the fire in the courtyard of the Monastery: (4)
As of 2017-11-24 20:53 GMT
Find Nodes?
    Voting Booth?
    In order to be able to say "I know Perl", you must have:

    Results (353 votes). Check out past polls.