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
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|