Beefy Boxes and Bandwidth Generously Provided by pair Networks
Pathologically Eclectic Rubbish Lister
 
PerlMonks  

Re: Controlling a Perl Daemon with Signals

by jch341277 (Sexton)
on Aug 05, 2005 at 21:49 UTC ( [id://481377]=note: print w/replies, xml ) Need Help??


in reply to Controlling a Perl Daemon with Signals

Actually it does work but the TERM interrupts the currently executing statement. Execution of the script starts with the next statement in the code after the signal handler returns.


If you add the following to your code and run the script using the debugger you'll see what I mean:

sub handle_request { sleep 13; sleep 14; }

Replies are listed 'Best First'.
Re^2: Controlling a Perl Daemon with Signals
by eastcoastcoder (Sexton) on Aug 05, 2005 at 22:32 UTC
    I should add that I have a few sleep calls in between iterations and the like - could that be causing the problem?
Re^2: Controlling a Perl Daemon with Signals
by eastcoastcoder (Sexton) on Aug 05, 2005 at 23:52 UTC
    I don't understand

      I've made some other changes to the code to illustrate what sk and I are talking about.

      use constant MAX_ITERATIONS => 100000; use constant MAX_TIME => 6000; use warnings; use strict; my $start_time = time; my $iterations = 0; my $exit_requested = 0; my $handling_request = 0; sub sig_handler { $exit_requested = 1; print "Caught interrupt\n"; exit(3) if !$handling_request; } $SIG{TERM} = \&sig_handler; #init(); while (!$exit_requested && $iterations <= MAX_ITERATIONS && (time - $s +tart_time) < MAX_TIME) { $handling_request = 1; handle_request(); $iterations++; $handling_request = 0; handlyn(); } exit(0); #sub init { return 1; } sub handle_request { handlyn(); print ("iterations: $iterations\n"); } sub handlyn { print $handling_request ? "" : "NOT ", "handling\n"; sle +ep 3; }

      The handlyn() gives me time to send a kill to the process which I'm running from the perl debugger. I then issue a "c 13" in the debugger and wait for the "NOT handling" to be printed, send a kill and then step into the script using "s". You'll see that when $handling_request == 1, the script will exit from line 15. When $handling_request == 0, the script exits from line 29. Which I think is how you want it?

      The question is - how does your handle_request work? Is it able to deal with being interrupted only to have execution return to some arbitrary line in the subroutine? What I've done here is to control where the interrupt will occur by giving myself time to send the interrupt at that particular line. But, that isn't how signals generally work in the wild...

      Update: corrected link.

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://481377]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others rifling through the Monastery: (6)
As of 2024-09-20 15:50 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?
    The PerlMonks site front end has:





    Results (26 votes). Check out past polls.

    Notices?
    erzuuli‥ 🛈The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.