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
|
|
|
|
2021-02-28 17:34:55 +08:00
|
|
|
use Annotation\Target;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Exception;
|
2020-09-04 01:05:33 +08:00
|
|
|
use HttpServer\Abstracts\Callback;
|
2020-09-07 16:50:26 +08:00
|
|
|
use Snowflake\Abstracts\Config;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Event;
|
2021-03-01 10:26:53 +08:00
|
|
|
use Snowflake\Exception\ComponentException;
|
2020-09-07 16:50:26 +08:00
|
|
|
use Snowflake\Exception\ConfigException;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Snowflake;
|
2021-02-28 00:41:22 +08:00
|
|
|
use Swoole\Coroutine;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Swoole\Server;
|
2021-03-01 19:16:41 +08:00
|
|
|
use co;
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Class OnWorkerStart
|
2020-09-02 11:38:47 +08:00
|
|
|
* @package HttpServer\Events
|
2020-08-31 01:27:08 +08:00
|
|
|
*/
|
2021-02-28 17:34:55 +08:00
|
|
|
#[Target]
|
2020-08-31 01:27:08 +08:00
|
|
|
class OnWorkerStart extends Callback
|
|
|
|
|
{
|
|
|
|
|
|
2021-03-01 16:07:44 +08:00
|
|
|
/** @var int 重启信号 */
|
|
|
|
|
private int $signal = SIGUSR1 | SIGUSR2 | SIGTERM;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $worker_id
|
|
|
|
|
*
|
|
|
|
|
* @return mixed
|
|
|
|
|
* @throws ConfigException
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public function onHandler(Server $server, int $worker_id): void
|
|
|
|
|
{
|
2021-03-01 19:16:41 +08:00
|
|
|
putenv('worker=' . $worker_id);
|
2021-03-01 16:07:44 +08:00
|
|
|
if ($worker_id >= $server->setting['worker_num']) {
|
|
|
|
|
$this->onTask($server, $worker_id);
|
|
|
|
|
} else {
|
|
|
|
|
$this->onWorker($server, $worker_id);
|
|
|
|
|
}
|
2021-03-01 19:01:57 +08:00
|
|
|
$this->debug(sprintf('%s #%d Pid:%d start.', ucfirst(env('environmental')), $worker_id, $server->worker_pid));
|
2021-03-01 19:18:43 +08:00
|
|
|
Coroutine\go([$this, 'onSignal'], $server, $worker_id);
|
2021-03-01 16:07:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $worker_id
|
|
|
|
|
* @throws ComponentException|ConfigException
|
|
|
|
|
*/
|
|
|
|
|
public function onTask(Server $server, int $worker_id)
|
|
|
|
|
{
|
|
|
|
|
putenv('environmental=' . Snowflake::TASK);
|
|
|
|
|
|
|
|
|
|
fire(Event::SERVER_TASK_START);
|
|
|
|
|
|
|
|
|
|
$this->set_process_name($server, $worker_id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $worker_id
|
|
|
|
|
* @throws Exception
|
|
|
|
|
* onWorker
|
|
|
|
|
*/
|
|
|
|
|
public function onWorker(Server $server, int $worker_id)
|
|
|
|
|
{
|
|
|
|
|
Snowflake::setWorkerId($server->worker_pid);
|
|
|
|
|
putenv('environmental=' . Snowflake::WORKER);
|
|
|
|
|
try {
|
|
|
|
|
fire(Event::SERVER_WORKER_START, [$worker_id]);
|
|
|
|
|
} catch (\Throwable $exception) {
|
|
|
|
|
$this->addError($exception);
|
|
|
|
|
write($exception->getMessage(), 'worker');
|
|
|
|
|
}
|
|
|
|
|
$this->set_process_name($server, $worker_id);
|
|
|
|
|
}
|
2021-02-27 04:48:44 +08:00
|
|
|
|
2021-02-28 17:15:06 +08:00
|
|
|
|
2021-03-01 10:26:53 +08:00
|
|
|
/**
|
|
|
|
|
* @param $server
|
|
|
|
|
* @param $worker_id
|
|
|
|
|
* @return mixed
|
2021-03-01 18:06:21 +08:00
|
|
|
* @throws ComponentException
|
2021-03-01 10:26:53 +08:00
|
|
|
*/
|
2021-03-01 18:06:21 +08:00
|
|
|
public function onSignal(Server $server, $worker_id): mixed
|
2021-03-01 16:07:44 +08:00
|
|
|
{
|
2021-03-01 17:19:02 +08:00
|
|
|
$ret = Coroutine::waitSignal($this->signal, -1);
|
2021-03-02 10:28:13 +08:00
|
|
|
if ($ret === true) {
|
2021-03-01 18:06:21 +08:00
|
|
|
$this->ticker();
|
|
|
|
|
}
|
|
|
|
|
return $server->stop();
|
2021-03-01 16:07:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2021-03-01 17:14:17 +08:00
|
|
|
/**
|
|
|
|
|
* @return void
|
2021-03-01 17:46:10 +08:00
|
|
|
* @throws ComponentException
|
2021-03-01 17:14:17 +08:00
|
|
|
*/
|
|
|
|
|
private function ticker(): void
|
2021-03-01 17:08:45 +08:00
|
|
|
{
|
|
|
|
|
if (!Snowflake::app()->isRun()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2021-03-02 10:53:24 +08:00
|
|
|
usleep(500);
|
2021-03-01 17:08:45 +08:00
|
|
|
$this->ticker();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2021-03-01 16:07:44 +08:00
|
|
|
/**
|
|
|
|
|
* @param $socket
|
|
|
|
|
* @param $worker_id
|
|
|
|
|
* @return string
|
|
|
|
|
* @throws ConfigException
|
|
|
|
|
*/
|
|
|
|
|
private function set_process_name($socket, $worker_id): mixed
|
|
|
|
|
{
|
|
|
|
|
$prefix = Config::get('id', false, 'system');
|
|
|
|
|
if ($worker_id >= $socket->setting['worker_num']) {
|
|
|
|
|
$name = $prefix . ' Task: No.' . $worker_id;
|
|
|
|
|
} else {
|
|
|
|
|
$name = $prefix . ' worker: No.' . $worker_id;
|
|
|
|
|
}
|
|
|
|
|
return swoole_set_process_name($name);
|
|
|
|
|
}
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|