Compare commits

...

12 Commits

Author SHA1 Message Date
as2252258 c260ac6df4 1 2021-11-27 17:43:28 +08:00
as2252258 7479bed4e4 改名 2021-11-19 17:37:50 +08:00
as2252258 39394f76d5 改名 2021-11-19 14:46:07 +08:00
as2252258 065555a80e 改名 2021-11-18 18:06:45 +08:00
as2252258 13a8ca73bd 改名 2021-11-18 18:01:03 +08:00
as2252258 8456e1b7d5 改名 2021-11-18 17:05:00 +08:00
as2252258 82b5650c8a 改名 2021-11-18 16:59:45 +08:00
as2252258 03601f2db6 改名 2021-11-18 16:54:15 +08:00
as2252258 a7082b76fd 改名 2021-11-18 16:40:57 +08:00
as2252258 e872e04da1 改名 2021-11-18 15:59:46 +08:00
as2252258 370b255862 改名 2021-11-18 15:57:37 +08:00
as2252258 d4b5bed960 改名 2021-11-18 15:37:10 +08:00
8 changed files with 39 additions and 122 deletions
-60
View File
@@ -80,64 +80,4 @@ abstract class BaseProcess implements OnProcessInterface
}
/**
* @return bool
*/
public function checkProcessIsStop(): bool
{
return $this->isStop === true;
}
/**
* @param Process $process
*/
public function signListen(Process $process): void
{
}
/**
*
*/
protected function exit(): void
{
putenv('process.status=idle');
}
/**
* @return bool
*/
#[Pure] public function isWorking(): bool
{
return env('process.status', 'working') == 'working';
}
/**
*
*/
private function waiteExit(Process $process): void
{
$this->onProcessStop();
while ($this->isWorking()) {
$this->sleep();
}
$process->exit(0);
}
/**
*
*/
private function sleep(): void
{
if ($this->enable_coroutine) {
Coroutine::sleep(0.1);
} else {
usleep(100);
}
}
}
-12
View File
@@ -1,12 +0,0 @@
<?php
namespace Server\Contract;
use Swoole\Http\Response;
interface OnDownloadInterface
{
public function dispatch(Response $response);
}
+1 -19
View File
@@ -17,27 +17,9 @@ interface OnProcessInterface
/**
* @param Process $process
* @return string
*/
public function getProcessName(Process $process): string;
public function process(Process $process): void;
/**
* @param Process $process
*/
public function signListen(Process $process): void;
/**
* @param Process $process
*/
public function onHandler(Process $process): void;
/**
*
*/
public function onProcessStop(): void;
}
+8
View File
@@ -0,0 +1,8 @@
<?php
namespace Server\Events;
class OnServerBeforeStart
{
}
-2
View File
@@ -8,7 +8,6 @@ use Kiri\Abstracts\Config;
use Kiri\Core\Help;
use Kiri\Events\EventDispatch;
use Kiri\Kiri;
use Kiri\Runtime;
use Server\Events\OnAfterWorkerStart;
use Server\Events\OnBeforeWorkerStart;
use Server\Events\OnTaskerStart as OnTaskStart;
@@ -16,7 +15,6 @@ use Server\Events\OnWorkerError;
use Server\Events\OnWorkerExit;
use Server\Events\OnWorkerStart;
use Server\Events\OnWorkerStop;
use Server\ServerManager;
use Swoole\Server;
use Swoole\Timer;
-1
View File
@@ -8,7 +8,6 @@ use Exception;
use Http\Handler\Abstracts\HttpService;
use JetBrains\PhpStorm\Pure;
use Kiri\Abstracts\Config;
use Kiri\Error\LoggerProcess;
use Kiri\Events\EventDispatch;
use Kiri\Exception\ConfigException;
use Server\Events\OnShutdown;
+8 -5
View File
@@ -7,9 +7,10 @@ namespace Server;
use Annotation\Inject;
use Exception;
use Kiri\Abstracts\Config;
use Kiri\Events\EventProvider;
use Kiri\Events\EventDispatch;
use Kiri\Exception\ConfigException;
use Kiri\Kiri;
use Server\Events\OnServerBeforeStart;
use Swoole\Coroutine;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
@@ -29,10 +30,10 @@ class ServerCommand extends Command
/**
* @var EventProvider
* @var EventDispatch
*/
#[Inject(EventProvider::class)]
public EventProvider $eventProvider;
#[Inject(EventDispatch::class)]
public EventDispatch $eventProvider;
/**
@@ -68,7 +69,7 @@ class ServerCommand extends Command
}
$manager->shutdown();
if ($input->getArgument('action') == 'stop') {
throw new Exception('shutdown success');
return 0;
}
return $this->generate_runtime_builder($manager);
}
@@ -105,6 +106,8 @@ class ServerCommand extends Command
Kiri::app()->getRouter()->read_files();
$this->eventProvider->dispatch(new OnServerBeforeStart());
$manager->start();
return 1;
+22 -23
View File
@@ -3,21 +3,16 @@
namespace Server;
use Annotation\Inject;
use Closure;
use Exception;
use Kiri\Abstracts\Config;
use Kiri\Di\ContainerInterface;
use Psr\Container\ContainerInterface;
use Kiri\Error\Logger;
use Kiri\Exception\ConfigException;
use Kiri\Kiri;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
use ReflectionException;
use Server\Abstracts\BaseProcess;
use Server\Handler\OnPipeMessage;
use Server\Handler\OnServer;
use Server\Handler\OnServerManager;
use Server\Handler\OnServerReload;
use Server\Handler\OnServerTask;
use Server\Handler\OnServerWorker;
use Server\Contract\OnCloseInterface;
use Server\Contract\OnConnectInterface;
use Server\Contract\OnDisconnectInterface;
@@ -27,6 +22,12 @@ use Server\Contract\OnPacketInterface;
use Server\Contract\OnProcessInterface;
use Server\Contract\OnReceiveInterface;
use Server\Contract\OnTaskInterface;
use Server\Handler\OnPipeMessage;
use Server\Handler\OnServer;
use Server\Handler\OnServerManager;
use Server\Handler\OnServerReload;
use Server\Handler\OnServerTask;
use Server\Handler\OnServerWorker;
use Swoole\Http\Server as HServer;
use Swoole\Process;
use Swoole\Server;
@@ -168,19 +169,14 @@ class ServerManager
if (is_string($customProcess)) {
$customProcess = Kiri::getDi()->get($customProcess);
}
$process = new Process(function (Process $soloProcess) use ($customProcess) {
$system = sprintf('[%s].process', Config::get('id', 'system-service'));
$system = sprintf('[%s].process', Config::get('id', 'system-service'));
$process = new Process(function (Process $process) use ($customProcess, $system) {
if (Kiri::getPlatform()->isLinux()) {
$soloProcess->name($system . '(' . $customProcess->getName() . ')');
$process->name($system . '(' . $customProcess->getName() . ')');
}
$this->logger->debug($system . $customProcess->getName() . ' start.');
$customProcess->signListen($soloProcess);
$customProcess->onHandler($soloProcess);
},
$customProcess->getRedirectStdinAndStdout(),
$customProcess->getPipeType(),
$customProcess->isEnableCoroutine()
);
$customProcess->process($process);
}, $customProcess->getRedirectStdinAndStdout(), $customProcess->getPipeType(), $customProcess->isEnableCoroutine());
$this->logger->debug($system . ' ' . $customProcess->getName() . ' start.');
$this->container->setBindings($customProcess->getName(), $process);
$this->server->addProcess($process);
}
@@ -238,6 +234,7 @@ class ServerManager
$config['settings']['log_file'] = storage('system.log');
}
$config['settings']['pid_file'] = storage('.swoole.pid');
$config['settings'][Constant::OPTION_ENABLE_REUSE_PORT] = true;
$config['events'] = $config['events'] ?? [];
return $config;
}
@@ -339,10 +336,12 @@ class ServerManager
}
/**
* @param array $events
* @param Server|Port $server
*/
/**
* @param array $events
* @param Server|Port $server
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
private function addServiceEvents(array $events, Server|Port $server)
{
foreach ($events as $name => $event) {