改名
This commit is contained in:
+56
-43
@@ -4,70 +4,83 @@
|
||||
namespace Server;
|
||||
|
||||
|
||||
use JetBrains\PhpStorm\Pure;
|
||||
use Swoole\Coroutine\Channel;
|
||||
|
||||
class ApplicationStore
|
||||
{
|
||||
|
||||
|
||||
private static ?ApplicationStore $applicationStore = null;
|
||||
private static ?ApplicationStore $applicationStore = null;
|
||||
|
||||
|
||||
private Channel $lock;
|
||||
private Channel $lock;
|
||||
|
||||
|
||||
private function __construct()
|
||||
{
|
||||
$this->lock = new Channel(99999);
|
||||
}
|
||||
private function __construct()
|
||||
{
|
||||
$this->lock = new Channel(99999);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @return \Server\ApplicationStore|null
|
||||
*/
|
||||
public static function getStore()
|
||||
{
|
||||
if (!(static::$applicationStore instanceof ApplicationStore)) {
|
||||
static::$applicationStore = new ApplicationStore();
|
||||
}
|
||||
return static::$applicationStore;
|
||||
}
|
||||
/**
|
||||
* @return ApplicationStore|null
|
||||
*/
|
||||
public static function getStore(): ?ApplicationStore
|
||||
{
|
||||
if (!(static::$applicationStore instanceof ApplicationStore)) {
|
||||
static::$applicationStore = new ApplicationStore();
|
||||
}
|
||||
return static::$applicationStore;
|
||||
}
|
||||
|
||||
|
||||
public function add()
|
||||
{
|
||||
$this->lock->push(1);
|
||||
return $this;
|
||||
}
|
||||
/**
|
||||
* @return $this
|
||||
*/
|
||||
public function add(): static
|
||||
{
|
||||
$this->lock->push(1);
|
||||
return $this;
|
||||
}
|
||||
|
||||
|
||||
public function waite()
|
||||
{
|
||||
$this->lock->pop(-1);
|
||||
}
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public function waite(): void
|
||||
{
|
||||
if ($this->lock->isEmpty()) {
|
||||
return;
|
||||
}
|
||||
$this->lock->pop(-1);
|
||||
}
|
||||
|
||||
|
||||
public function done()
|
||||
{
|
||||
$this->lock->pop();
|
||||
}
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public function done(): void
|
||||
{
|
||||
$this->lock->pop();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @return bool
|
||||
*/
|
||||
public function isBusy()
|
||||
{
|
||||
return !$this->lock->isEmpty();
|
||||
}
|
||||
/**
|
||||
* @return bool
|
||||
*/
|
||||
public function isBusy(): bool
|
||||
{
|
||||
return !$this->lock->isEmpty();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function getStatus(): string
|
||||
{
|
||||
return env('state');
|
||||
}
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
#[Pure] public function getStatus(): string
|
||||
{
|
||||
return env('state');
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -92,6 +92,8 @@ class HTTPServerListener extends Abstracts\Server
|
||||
{
|
||||
try {
|
||||
// defer(fn() => fire(Event::SYSTEM_RESOURCE_RELEASES));
|
||||
ApplicationStore::getStore()->waite();
|
||||
|
||||
/** @var \HttpServer\Http\Response $sResponse */
|
||||
[$sRequest, $sResponse] = $this->request($request, $response);
|
||||
|
||||
|
||||
@@ -5,6 +5,7 @@ namespace Server\Worker;
|
||||
use Annotation\Annotation;
|
||||
use Exception;
|
||||
use ReflectionException;
|
||||
use Server\ApplicationStore;
|
||||
use Server\Constant;
|
||||
use Snowflake\Abstracts\Config;
|
||||
use Snowflake\Core\Help;
|
||||
@@ -33,6 +34,9 @@ class ServerWorker extends \Server\Abstracts\Server
|
||||
public function onWorkerStart(Server $server, int $workerId)
|
||||
{
|
||||
$this->_setConfigCache($workerId);
|
||||
|
||||
$store = ApplicationStore::getStore()->add();
|
||||
|
||||
$annotation = Snowflake::app()->getAnnotation();
|
||||
$annotation->read(APP_PATH . 'app');
|
||||
|
||||
@@ -40,6 +44,8 @@ class ServerWorker extends \Server\Abstracts\Server
|
||||
|
||||
$this->workerInitExecutor($server, $annotation, $workerId);
|
||||
$this->interpretDirectory($annotation);
|
||||
|
||||
$store->done();
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user