[Chicago-talk] Determining if another perl process is running.

Andy Bach Andy_Bach at wiwb.uscourts.gov
Mon Nov 25 07:41:33 PST 2024


Need to expand your grep RE or add a grep -v to remove the ones you don't want, though, then you have to remove the one you just added.  Another is to track the pids, find the ones you've created and look for one outside that set.  You could have starman (if it doesn't) create a .pid file and use that to check that pid's status (with lsof -p <pid> maybe), rather than grepping.
________________________________
From: Chicago-talk <chicago-talk-bounces+andy_bach=wiwb.uscourts.gov at pm.org> on behalf of Richard Reina <gatorreina at gmail.com>
Sent: Sunday, November 24, 2024 5:19 PM
To: Chicago.pm chatter <chicago-talk at pm.org>
Subject: [Chicago-talk] Determining if another perl process is running.

CAUTION - EXTERNAL:

Hello everyone,

So excited about the Winter Perl Conference that I just registered for that I thought I would rebuild my aged Perl Dancer2 website. I 've done so and deployed it on a Digital Ocean droplet but I've hit a snag in setting up a cron job to make sure starman is running. It seems my query into whether the process is running gets treated as evidence that the process IS running.

When I do:

perl -e 'my $smstat = `ps -ef | grep starman`; unless ($smstat =~ /starman master/) { system("XDG_RUNTIME_DIR=/run/user/1001 exec /home/starman/starman.pl<http://starman.pl> start &>> /home/starman/starman.log"); print localtime . " starting starman\n"; } else { print "Starman is already running\n\n\n $smstat\n" }';

RESULTS IN:

Starman is already running


 starman   203805       1  0 Nov08 ?        00:00:00 /lib/systemd/systemd --user
starman   203806  203805  0 Nov08 ?        00:00:00 (sd-pam)
root      472040     385  0 Nov20 ?        00:00:00 sshd: starman [priv]
starman   472049  472040  0 Nov20 ?        00:00:01 sshd: starman at pts/0
starman   472050  472049  0 Nov20 pts/0    00:00:00 -bash
starman   544383  472050  0 23:11 pts/0    00:00:00 perl -e my $smstat = `ps -ef | grep starman`; unless ($smstat =~ /starman master/) { system("XDG_RUNTIME_DIR=/run/user/1001 exec /home/starman/starman.pl<http://starman.pl> start &>> /home/starman/starman.log"); print localtime . " starting starman\n"; } else { print "Starman is already running\n\n\n $smstat\n" }
starman   544384  544383  0 23:11 pts/0    00:00:00 sh -c ps -ef | grep starman
starman   544385  544384  0 23:11 pts/0    00:00:00 ps -ef
starman   544386  544384  0 23:11 pts/0    00:00:00 grep starman

It always says it's running even if it is not apparently because it's seeing 'starman master/ in the perl script that is inquiring.

Anyone know a good solution to avoid this so that I can determine whether my starman startup script is indeed running?

CAUTION - EXTERNAL EMAIL: This email originated outside the Judiciary. Exercise caution when opening attachments or clicking on links.

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.pm.org/pipermail/chicago-talk/attachments/20241125/63d6658b/attachment-0001.html>


More information about the Chicago-talk mailing list