变更
This commit is contained in:
@@ -14,13 +14,13 @@ use Psr\Log\LoggerInterface;
|
||||
use ReflectionException;
|
||||
use Kiri\Server\Config as SConfig;
|
||||
use Kiri\Di\LocalService;
|
||||
use Swoole\Runtime;
|
||||
use Swoole\Server;
|
||||
use Kiri\Server\ServerInterface;
|
||||
use Kiri\Server\Constant;
|
||||
use Kiri\Events\EventDispatch;
|
||||
use Kiri\Exception\NotFindClassException;
|
||||
use Kiri\Server\Events\OnServerBeforeStart;
|
||||
use Kiri\Di\Inject\Container;
|
||||
|
||||
/**
|
||||
*
|
||||
@@ -44,11 +44,11 @@ class AsyncServer implements ServerInterface
|
||||
* @param LoggerInterface $logger
|
||||
* @param ProcessManager $processManager
|
||||
*/
|
||||
public function __construct(public Config $config,
|
||||
public ContainerInterface $container,
|
||||
public EventDispatch $dispatch,
|
||||
public LoggerInterface $logger,
|
||||
public ProcessManager $processManager)
|
||||
public function __construct(#[Container(Config::class)] public Config $config,
|
||||
#[Container(ContainerInterface::class)] public ContainerInterface $container,
|
||||
#[Container(EventDispatch::class)] public EventDispatch $dispatch,
|
||||
#[Container(LoggerInterface::class)] public LoggerInterface $logger,
|
||||
#[Container(ProcessManager::class)] public ProcessManager $processManager)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
@@ -12,10 +12,10 @@ use Psr\Container\ContainerExceptionInterface;
|
||||
use Psr\Container\NotFoundExceptionInterface;
|
||||
use Swoole\Coroutine;
|
||||
use Swoole\Process;
|
||||
use Kiri\Annotation\Inject;
|
||||
use Psr\Container\ContainerInterface;
|
||||
use Kiri\Events\EventProvider;
|
||||
use Kiri\Server\ServerInterface;
|
||||
use Kiri\Di\Inject\Container;
|
||||
use Kiri\Server\Events\OnServerBeforeStart;
|
||||
|
||||
class ProcessManager extends Component
|
||||
@@ -29,11 +29,11 @@ class ProcessManager extends Component
|
||||
/**
|
||||
* @var ContainerInterface
|
||||
*/
|
||||
#[Inject(ContainerInterface::class)]
|
||||
#[Container(ContainerInterface::class)]
|
||||
public ContainerInterface $container;
|
||||
|
||||
|
||||
#[Inject(EventProvider::class)]
|
||||
#[Container(EventProvider::class)]
|
||||
public EventProvider $provider;
|
||||
|
||||
/**
|
||||
|
||||
@@ -4,12 +4,10 @@
|
||||
namespace Kiri\Server\Abstracts;
|
||||
|
||||
|
||||
use Kiri\Annotation\Inject;
|
||||
use Exception;
|
||||
use Kiri\Abstracts\Config;
|
||||
use Kiri\Exception\ConfigException;
|
||||
use Kiri;
|
||||
use Psr\Log\LoggerInterface;
|
||||
use Kiri\Di\Inject\Container;
|
||||
|
||||
|
||||
/**
|
||||
@@ -23,7 +21,7 @@ abstract class Server
|
||||
/**
|
||||
* @var LoggerInterface
|
||||
*/
|
||||
#[Inject(LoggerInterface::class)]
|
||||
#[Container(LoggerInterface::class)]
|
||||
public LoggerInterface $logger;
|
||||
|
||||
|
||||
|
||||
+6
-5
@@ -4,6 +4,7 @@ namespace Kiri\Server;
|
||||
|
||||
use Exception;
|
||||
use Kiri\Abstracts\Config;
|
||||
use Kiri\Di\Inject\Container;
|
||||
use Psr\Container\ContainerInterface;
|
||||
use Kiri\Events\EventDispatch;
|
||||
use Kiri\Exception\ConfigException;
|
||||
@@ -50,11 +51,11 @@ class CoroutineServer implements ServerInterface
|
||||
* @param LoggerInterface $logger
|
||||
* @param ProcessManager $processManager
|
||||
*/
|
||||
public function __construct(public Config $config,
|
||||
public ContainerInterface $container,
|
||||
public EventDispatch $dispatch,
|
||||
public LoggerInterface $logger,
|
||||
public ProcessManager $processManager)
|
||||
public function __construct(#[Container(Config::class)] public Config $config,
|
||||
#[Container(ContainerInterface::class)] public ContainerInterface $container,
|
||||
#[Container(EventDispatch::class)] public EventDispatch $dispatch,
|
||||
#[Container(LoggerInterface::class)] public LoggerInterface $logger,
|
||||
#[Container(ProcessManager::class)] public ProcessManager $processManager)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
@@ -3,8 +3,6 @@
|
||||
namespace Kiri\Server\Handler;
|
||||
|
||||
use Exception;
|
||||
use Kiri\Annotation\Inject;
|
||||
use Kiri\Events\EventDispatch;
|
||||
use Kiri\Server\Abstracts\Server;
|
||||
use Kiri\Server\Contract\OnPipeMessageInterface;
|
||||
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace Kiri\Server\Handler;
|
||||
|
||||
use Kiri;
|
||||
use Kiri\Annotation\Inject;
|
||||
use Kiri\Events\EventDispatch;
|
||||
use Psr\Container\ContainerExceptionInterface;
|
||||
use Psr\Container\NotFoundExceptionInterface;
|
||||
|
||||
@@ -7,8 +7,6 @@ use Kiri;
|
||||
use Kiri\Abstracts\Config;
|
||||
use Kiri\Core\Help;
|
||||
use Kiri\Events\EventDispatch;
|
||||
use Kiri\Message\Handler\Router;
|
||||
use Kiri\Server\Constant;
|
||||
use Kiri\Server\Events\OnAfterWorkerStart;
|
||||
use Kiri\Server\Events\OnBeforeWorkerStart;
|
||||
use Kiri\Server\Events\OnTaskerStart as OnTaskStart;
|
||||
@@ -19,12 +17,9 @@ use Kiri\Server\Events\OnWorkerStop;
|
||||
use Psr\Container\ContainerExceptionInterface;
|
||||
use Psr\Container\NotFoundExceptionInterface;
|
||||
use ReflectionException;
|
||||
use Swoole\Runtime;
|
||||
use Swoole\Server;
|
||||
use Kiri\Server\Abstracts\StatusEnum;
|
||||
use Kiri\Server\WorkerStatus;
|
||||
use Swoole\Timer;
|
||||
use Kiri\Annotation\Inject;
|
||||
|
||||
|
||||
/**
|
||||
@@ -134,7 +129,7 @@ class OnServerWorker extends \Kiri\Server\Abstracts\Server
|
||||
Help::sendEmail($email, 'Service Error', $messageContent);
|
||||
}
|
||||
} catch (\Throwable $e) {
|
||||
error($e, 'email');
|
||||
error($e, ['email']);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
+19
-28
@@ -20,6 +20,7 @@ use Kiri\Server\Events\OnWorkerStop;
|
||||
use Swoole\Coroutine;
|
||||
use Kiri\Server\Abstracts\ProcessManager;
|
||||
use Kiri\Server\Abstracts\AsyncServer;
|
||||
use Kiri\Di\Inject\Container;
|
||||
|
||||
|
||||
defined('PID_PATH') or define('PID_PATH', APP_PATH . 'storage/server.pid');
|
||||
@@ -37,27 +38,23 @@ class Server
|
||||
|
||||
public AsyncServer|CoroutineServer $manager;
|
||||
|
||||
#[Container(State::class)]
|
||||
public State $state;
|
||||
|
||||
/**
|
||||
* @param State $state
|
||||
* @param ContainerInterface $container
|
||||
* @param ProcessManager $processManager
|
||||
* @param EventDispatch $dispatch
|
||||
* @param EventProvider $provider
|
||||
* @param Router $router
|
||||
* @param array $config
|
||||
* @throws Exception
|
||||
*/
|
||||
public function __construct(public State $state,
|
||||
public ContainerInterface $container,
|
||||
public ProcessManager $processManager,
|
||||
public EventDispatch $dispatch,
|
||||
public EventProvider $provider,
|
||||
public Router $router,
|
||||
array $config = [])
|
||||
{
|
||||
parent::__construct($config);
|
||||
}
|
||||
#[Container(ContainerInterface::class)]
|
||||
public ContainerInterface $container;
|
||||
|
||||
#[Container(ProcessManager::class)]
|
||||
public ProcessManager $processManager;
|
||||
|
||||
#[Container(EventDispatch::class)]
|
||||
public EventDispatch $dispatch;
|
||||
|
||||
#[Container(EventProvider::class)]
|
||||
public EventProvider $provider;
|
||||
|
||||
#[Container(Router::class)]
|
||||
public Router $router;
|
||||
|
||||
|
||||
/**
|
||||
@@ -67,7 +64,7 @@ class Server
|
||||
*/
|
||||
public function init(): void
|
||||
{
|
||||
$this->manager = $this->container->get(Config::get('server.type',AsyncServer::class));
|
||||
$this->manager = $this->container->get(Config::get('server.type', AsyncServer::class));
|
||||
|
||||
$enable_coroutine = Config::get('server.settings.enable_coroutine', false);
|
||||
if (!$enable_coroutine) {
|
||||
@@ -160,13 +157,7 @@ class Server
|
||||
public function onHotReload(): void
|
||||
{
|
||||
$this->onWorkerListener();
|
||||
$reload = Config::get('reload.hot', false);
|
||||
if ($reload !== false) {
|
||||
$this->provider->on(OnWorkerStart::class, [$this->router, 'scan_build_route']);
|
||||
$this->manager->addProcess(Kiri\Reload\Inotify::class);
|
||||
} else {
|
||||
$this->router->scan_build_route();
|
||||
}
|
||||
$this->router->scan_build_route();
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user