Page MenuHomePhabricator

When stopping subprocesses, send SIGTERM first, then SIGKILL if that doesn't work
ClosedPublic

Authored by epriestley on Sep 7 2016, 1:18 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 17, 5:07 PM
Unknown Object (File)
Thu, Jan 16, 10:06 AM
Unknown Object (File)
Fri, Jan 10, 2:58 PM
Unknown Object (File)
Tue, Dec 31, 4:45 AM
Unknown Object (File)
Sat, Dec 28, 2:17 PM
Unknown Object (File)
Wed, Dec 25, 2:05 PM
Unknown Object (File)
Mon, Dec 23, 4:11 AM
Unknown Object (File)
Dec 19 2024, 9:05 PM
Subscribers
None

Details

Summary

Fixes T11592. This improves our ability to clean up subprocess trees:

  • When killing a subprocess, send it SIGTERM first. If that doesn't work, wait a little while and send it SIGKILL.
  • When exiting via __destruct() (for example, in response to recieving SIGTERM ourselves) try to SIGTERM children. We wait a shorter period of time for them to exit in this case (5 seconds).
Test Plan

Used several scripts that run one another:

test.php
<?php

require_once '../libphutil/scripts/__init_script__.php';

echo getmypid()."\n";

$future = new ExecFuture('php -f test2.php');
$future->setTimeout(1);
var_dump($future->resolve());
test2.php
<?php

require_once '../libphutil/scripts/__init_script__.php';

echo getmypid()."\n";

$future = new ExecFuture('sleep 240');
$future->resolve();

...and added this snippet to SignalRouter:

$status = getmypid().' got '.$signo."\n";
Filesystem::appendFile('/tmp/signal.log', $status);
echo $status;

Then I ran test.php and signaled it. I saw it TERM the subprocess, which TERM'd the sleep and everything exited properly.

I also ran resist-death.php from libphutil (which ignores signals) with setTimeout() and saw it get TERM'd and then KILL'd a short time later.

Diff Detail

Repository
rPHU libphutil
Branch
signal2
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 13603
Build 17525: Run Core Tests
Build 17524: arc lint + arc unit

Event Timeline

epriestley retitled this revision from to When stopping subprocesses, send SIGTERM first, then SIGKILL if that doesn't work.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: chad.
chad edited edge metadata.
This revision is now accepted and ready to land.Sep 7 2016, 4:25 AM
epriestley edited edge metadata.
  • Only install pcntl_signal() conditionally (i.e., not on Windows). Fixes T11603.
  • Use proc_terminate() to send TERM instead of posix_kill(), also for Windows.
This revision was automatically updated to reflect the committed changes.