Making sure script only runs once instance at a time.
Hari Sekhon
hpsekhon at googlemail.com
Mon Oct 2 06:18:30 EDT 2006
AMENDMENT:
The line
number_procs=commands.getstatusoutput('ps -ef|grep %s|grep -v grep|wc
-l' % scriptpath)
was supposed to be
number_procs=int(commands.getstatusoutput('ps -ef|grep %s|grep -v
grep|wc -l' % scriptpath)[1])
-h
Hari Sekhon
Hari Sekhon wrote:
> Fredrik Lundh wrote:
>> Hari Sekhon wrote:
>>
>>
>>> I'm not sure if that is a very old way of doing it, which is why I was
>>> reluctant to do it. My way actually uses the process list of the os
>>> (linux) and counts the number of instances. If it is more than 0 then
>>> another process is running and the script exits gracefully.
>>>
>>
>> the code that reliably identifies instances of a given program would be
>> interesting to see.
>>
>>
>>> Also, apart from the fact the using lockfiles feels a bit 1970s, I have
>>>
>> > found that in real usage of other programs within the company that use
>> > lockfiles, it sometimes causes a bit of troubleshooting time when
>> > it stops working due to a stale lockfile.
>>
>> to minimize that risk, store the pid in the lockfile (and preferrably
>> also the host name), and make sure that the program checks that the pid
>> is still active before it "stops working".
>>
>> </F>
>>
>>
>
> How exactly do you check that the pid is still active in python? Is
> there a library or something that will allow me to manipulate system
> processes and listings etc the way everybody does in unix shells....
>
> I'm a huge fan of shell so I've done my own thing which leans on shell
> as follows:
>
> import sys,commands,os
>
> scriptpath = sys.argv[0]
> scriptname = os.path.basename(scriptpath)
>
> number_procs=commands.getstatusoutput('ps -ef|grep %s|grep -v grep|wc
> -l' % scriptpath)
>
> if number_procs > 1:
> print "There appears to be another %s process running." % scriptname
> print "Please do not run more than one instance of this program"
> print "Quitting for safety..."
> sys.exit(200)
>
> This works nicely for me.
>
> You might also want to add a bit of discrimination to the script
> (something along the lines of "get a decent os"...since this won't
> work on windows)
>
> import platform
> if platform.system() != 'Linux':
> print "Sorry but this program can only be run on Linux"
> sys.exit(201)
> #todo: should do a bit extra for our bsd cousins here....
>
>
> Let me know if you think you have a better way. Please provide a code
> snippet if so.
>
> -h
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.python.org/pipermail/python-list/attachments/20061002/c9df85a5/attachment.html>
More information about the Python-list
mailing list