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
|
|
|
|
2021-04-23 03:25:03 +08:00
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $worker_id
|
|
|
|
|
* @param int $worker_pid
|
|
|
|
|
* @param int $exit_code
|
|
|
|
|
* @param int $signal
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public function onHandler(Server $server, int $worker_id, int $worker_pid, int $exit_code, int $signal)
|
|
|
|
|
{
|
2021-04-27 15:57:50 +08:00
|
|
|
Event::trigger(Event::SERVER_WORKER_ERROR);
|
2021-04-23 03:25:03 +08:00
|
|
|
|
2021-05-04 02:05:06 +08:00
|
|
|
$message = sprintf('Worker#%d::%d error stop. signal %d, exit_code %d, msg %s',
|
|
|
|
|
$worker_id, $worker_pid, $signal, $exit_code, swoole_strerror(swoole_last_error())
|
2021-04-23 03:25:03 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
write($message, 'worker-exit');
|
|
|
|
|
}
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
}
|