Controlling Concurrent Runs with Perl

Get the WebProNews Newsletter:

[ Business]

Sometimes you have a program that can’t be run by more than one person, or one that must run frequently but you don’t know for sure how long an instance of it will take.

One way to accomplish that is to use a lock file.

open(CNT, "/tmp/mylockfile");
flock CNT,2;
# program hangs here until other instance is done
# .. other processing when it is free
# release the lock
flock CNT,8;
close CNT;

If an instance is running, another instance will be stopped at the “flock CNT,2;” line and won’t continue until the first program executes “flock CNT,8;”.

But what if you don’t want to just hang? An easy way to do that is to write your PID to a file:

open (L, "/tmp/mypid.lock");
close L;
$stat=kill 0, $pid ;
chomp $stat;
chomp $pid;
if ($stat and $pid) {
print "\nExiting because $pid exists\n";
exit 1;
open (L, ">/tmp/mypid.lock");
print L "$$\n";
close L;
.. other code

The “kill 0″ actually doesn’t even send a signal; it just checks to see if the process exists. If it does, we print a message and exit; otherwise the code continues.

These are two simple ways to control program execution with Perl.

*Originally published at APLawrence.com

A.P. Lawrence provides SCO Unix and Linux consulting services http://www.pcunix.com

Controlling Concurrent Runs with Perl
Comments Off
Top Rated White Papers and Resources

Comments are closed.

  • Join for Access to Our Exclusive Web Tools
  • Sidebar Top
  • Sidebar Middle
  • Sign Up For The Free Newsletter
  • Sidebar Bottom