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

43 lines
949 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-05-04 03:36:36 +08:00
use Snowflake\Abstracts\Config;
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',
2021-05-04 02:10:43 +08:00
$worker_id, $worker_pid, $signal, $exit_code, swoole_strerror(swoole_last_error(), 9)
2021-04-23 03:25:03 +08:00
);
write($message, 'worker-exit');
2021-05-04 03:36:36 +08:00
2021-05-06 14:58:42 +08:00
$this->system_mail($message);
2021-04-23 03:25:03 +08:00
}
2020-08-31 01:27:08 +08:00
}