From 22b6d7c67bb86722cf380dbaed55ff1a3fc84053 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20Rish=C3=B8j?= Date: Wed, 14 Dec 2022 22:24:14 +0700 Subject: [PATCH] Add signal option to `horizon:purge` (e.g. `SIGKILL`) (#1226) * add signal option (e.g. SIGKILL) * formatting Co-authored-by: Taylor Otwell --- src/Console/PurgeCommand.php | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/src/Console/PurgeCommand.php b/src/Console/PurgeCommand.php index 9ce8819b..dd791a4b 100644 --- a/src/Console/PurgeCommand.php +++ b/src/Console/PurgeCommand.php @@ -17,7 +17,8 @@ class PurgeCommand extends Command * * @var string */ - protected $signature = 'horizon:purge'; + protected $signature = 'horizon:purge + {--signal=SIGTERM : The signal to send to the rogue processes}'; /** * The console command description. @@ -69,9 +70,13 @@ public function __construct( */ public function handle(MasterSupervisorRepository $masters) { + $signal = is_numeric($signal = $this->option('signal')) + ? $signal + : constant($signal); + foreach ($masters->names() as $master) { if (Str::startsWith($master, MasterSupervisor::basename())) { - $this->purge($master); + $this->purge($master, $signal); } } } @@ -80,11 +85,12 @@ public function handle(MasterSupervisorRepository $masters) * Purge any orphan processes. * * @param string $master + * @param int $signal * @return void */ - public function purge($master) + public function purge($master, $signal = SIGTERM) { - $this->recordOrphans($master); + $this->recordOrphans($master, $signal); $expired = $this->processes->orphanedFor( $master, $this->supervisors->longestActiveTimeout() @@ -93,7 +99,7 @@ public function purge($master) collect($expired)->each(function ($processId) use ($master) { $this->comment("Killing Process: {$processId}"); - exec("kill {$processId}"); + exec("kill -s {$signal} {$processId}"); $this->processes->forgetOrphans($master, [$processId]); }); @@ -103,9 +109,10 @@ public function purge($master) * Record the orphaned Horizon processes. * * @param string $master + * @param int $signal * @return void */ - protected function recordOrphans($master) + protected function recordOrphans($master, $signal) { $this->processes->orphaned( $master, $orphans = $this->inspector->orphaned() @@ -114,7 +121,7 @@ protected function recordOrphans($master) foreach ($orphans as $processId) { $this->info("Observed Orphan: {$processId}"); - if (! posix_kill($processId, SIGTERM)) { + if (! posix_kill($processId, $signal)) { $this->error("Failed to kill process for Orphan: {$processId} (".posix_strerror(posix_get_last_error()).')'); } }