Files
kiri-core/HttpServer/Events/OnWorkerError.php
T

44 lines
809 B
PHP
Raw Normal View History

2020-08-31 01:27:08 +08:00
<?php
2020-10-29 18:17:25 +08:00
declare(strict_types=1);
2020-08-31 01:27:08 +08:00
2020-09-02 11:38:47 +08:00
namespace HttpServer\Events;
2020-08-31 01:27:08 +08:00
2020-09-02 17:33:48 +08:00
use Exception;
2020-09-04 01:05:33 +08:00
use HttpServer\Abstracts\Callback;
2021-03-02 18:16:34 +08:00
use Snowflake\Event;
use Snowflake\Snowflake;
2020-09-02 17:33:48 +08:00
use Swoole\Server;
2020-08-31 01:27:08 +08:00
2020-10-29 18:17:25 +08:00
/**
* Class OnWorkerError
* @package HttpServer\Events
*/
2020-08-31 01:27:08 +08:00
class OnWorkerError extends Callback
{
2021-03-02 18:17:22 +08:00
2020-08-31 01:27:08 +08:00
/**
2020-09-02 17:33:48 +08:00
* @param Server $server
* @param int $worker_id
* @param int $worker_pid
* @param int $exit_code
* @param int $signal
2020-09-02 19:09:32 +08:00
* @throws Exception
2020-08-31 01:27:08 +08:00
*/
2020-09-02 17:33:48 +08:00
public function onHandler(Server $server, int $worker_id, int $worker_pid, int $exit_code, int $signal)
2020-08-31 01:27:08 +08:00
{
2021-03-02 18:16:34 +08:00
$event = Snowflake::app()->getEvent();
$event->trigger(Event::SERVER_WORKER_ERROR);
2021-04-07 11:26:58 +08:00
$message = sprintf('Worker#%d error stop. signal %d, exit_code %d',
$worker_id, $signal, $exit_code
);
write($message, 'worker-exit');
2021-04-07 14:17:24 +08:00
logger_insert();
2020-08-31 01:27:08 +08:00
}
}