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
|
|
|
|
|
|
|
|
|
|
|
|
|
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-02-26 19:31:04 +08:00
|
|
|
use Snowflake\Exception\ComponentException;
|
2020-09-07 16:50:26 +08:00
|
|
|
use Snowflake\Exception\ConfigException;
|
2021-02-27 03:16:30 +08:00
|
|
|
use Snowflake\Process\Process;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Snowflake;
|
2021-02-26 17:58:29 +08:00
|
|
|
use Swoole\Coroutine;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Swoole\Server;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Class OnWorkerStart
|
2020-09-02 11:38:47 +08:00
|
|
|
* @package HttpServer\Events
|
2020-08-31 01:27:08 +08:00
|
|
|
*/
|
|
|
|
|
class OnWorkerStart extends Callback
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
2021-02-27 02:40:22 +08:00
|
|
|
private int $_taskTable = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $worker_id
|
|
|
|
|
*
|
|
|
|
|
* @return mixed
|
|
|
|
|
* @throws ConfigException
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public function onHandler(Server $server, int $worker_id): void
|
|
|
|
|
{
|
|
|
|
|
Coroutine::set(['enable_deadlock_check' => false]);
|
2021-02-27 03:18:54 +08:00
|
|
|
Coroutine::create(function () use ($server, $worker_id) {
|
|
|
|
|
$this->onTaskSignal($server, $worker_id);
|
|
|
|
|
});
|
2021-02-27 02:40:22 +08:00
|
|
|
|
|
|
|
|
$get_name = $this->get_process_name($server, $worker_id);
|
|
|
|
|
if (!empty($get_name) && !Snowflake::isMac()) {
|
|
|
|
|
swoole_set_process_name($get_name);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
putenv('workerId=' . ($worker_id >= $server->setting['worker_num'] ? 'Task' : 'Worker') . '.' . $worker_id);
|
|
|
|
|
if ($worker_id >= $server->setting['worker_num']) {
|
|
|
|
|
fire(Event::SERVER_TASK_START);
|
|
|
|
|
} else {
|
|
|
|
|
Snowflake::setWorkerId($server->worker_pid);
|
|
|
|
|
$this->setWorkerAction($worker_id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2021-02-27 03:39:07 +08:00
|
|
|
|
2021-02-27 02:40:22 +08:00
|
|
|
/**
|
|
|
|
|
* @param Server $server
|
|
|
|
|
* @param int $workerId
|
|
|
|
|
* 异步任务管制
|
|
|
|
|
*/
|
2021-02-27 02:42:26 +08:00
|
|
|
public function onTaskSignal(Server $server, int $workerId)
|
2021-02-27 02:40:22 +08:00
|
|
|
{
|
2021-02-27 03:18:54 +08:00
|
|
|
try {
|
2021-02-27 03:25:48 +08:00
|
|
|
$sigkill = Coroutine::waitSignal(SIGTERM | SIGKILL | SIGUSR2 | SIGUSR1);
|
2021-02-27 03:18:54 +08:00
|
|
|
var_dump($sigkill);
|
|
|
|
|
if ($sigkill !== false) {
|
|
|
|
|
while (Snowflake::app()->isRun()) {
|
|
|
|
|
Coroutine::sleep(1);
|
2021-02-27 02:45:55 +08:00
|
|
|
}
|
2021-02-27 02:40:22 +08:00
|
|
|
}
|
2021-02-27 03:38:32 +08:00
|
|
|
go(function () use ($server) {
|
|
|
|
|
Coroutine::waitPid($server->worker_pid);
|
|
|
|
|
});
|
|
|
|
|
$server->stop($workerId);;
|
2021-02-27 03:18:54 +08:00
|
|
|
} catch (\Throwable $exception) {
|
|
|
|
|
$this->addError($exception);
|
|
|
|
|
}
|
2021-02-27 02:40:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $worker_id
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
private function setWorkerAction($worker_id)
|
|
|
|
|
{
|
|
|
|
|
$event = Snowflake::app()->getEvent();
|
|
|
|
|
try {
|
|
|
|
|
$this->debug(sprintf('Worker #%d is start.....', $worker_id));
|
|
|
|
|
$event->trigger(Event::SERVER_WORKER_START, [$worker_id]);
|
|
|
|
|
} catch (\Throwable $exception) {
|
|
|
|
|
$this->addError($exception);
|
|
|
|
|
write($exception->getMessage(), 'worker');
|
|
|
|
|
}
|
|
|
|
|
try {
|
|
|
|
|
$event->trigger(Event::SERVER_AFTER_WORKER_START, [$worker_id]);
|
|
|
|
|
} catch (\Throwable $exception) {
|
|
|
|
|
$this->addError($exception);
|
|
|
|
|
write($exception->getMessage(), 'worker');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $socket
|
|
|
|
|
* @param $worker_id
|
|
|
|
|
* @return string
|
|
|
|
|
* @throws ConfigException
|
|
|
|
|
*/
|
|
|
|
|
private function get_process_name($socket, $worker_id): string
|
|
|
|
|
{
|
|
|
|
|
$prefix = rtrim(Config::get('id', false, 'system:'), ':');
|
|
|
|
|
if ($worker_id >= $socket->setting['worker_num']) {
|
|
|
|
|
return $prefix . ': Task: No.' . $worker_id;
|
|
|
|
|
} else {
|
|
|
|
|
return $prefix . ': worker: No.' . $worker_id;
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|