2022-01-09 14:00:32 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace Kiri\Rpc;
|
|
|
|
|
|
2022-01-13 18:25:29 +08:00
|
|
|
use Exception;
|
|
|
|
|
use Kiri;
|
2022-05-31 10:53:33 +08:00
|
|
|
use Kiri\Abstracts\Config;
|
2022-01-09 14:00:32 +08:00
|
|
|
use Kiri\Abstracts\Component;
|
2022-03-02 15:15:36 +08:00
|
|
|
use Kiri\Annotation\Inject;
|
2022-01-09 14:00:32 +08:00
|
|
|
use Kiri\Consul\Agent;
|
|
|
|
|
use Kiri\Consul\Health;
|
2022-03-02 16:27:15 +08:00
|
|
|
use Kiri\Message\Handler\Router;
|
2022-01-09 14:00:32 +08:00
|
|
|
|
|
|
|
|
class RpcManager extends Component
|
|
|
|
|
{
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
|
|
|
|
* @var array
|
|
|
|
|
*/
|
|
|
|
|
private array $_rpc = [];
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-03-02 15:15:36 +08:00
|
|
|
#[Inject(Health::class)]
|
|
|
|
|
public Health $health;
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-13 18:25:29 +08:00
|
|
|
/**
|
|
|
|
|
* @param string $serviceName
|
|
|
|
|
* @return void
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
2022-05-31 11:02:15 +08:00
|
|
|
public function reRegister(): void
|
2022-05-31 10:53:33 +08:00
|
|
|
{
|
2022-01-13 18:25:29 +08:00
|
|
|
$service = Kiri::getDi()->get(Agent::class);
|
2022-05-31 10:53:33 +08:00
|
|
|
|
2022-05-31 11:02:15 +08:00
|
|
|
$config = Config::get("rpc.consul", null, true);
|
|
|
|
|
|
2022-01-13 18:25:29 +08:00
|
|
|
$info = $service->service->service_health($config['config']['ID']);
|
|
|
|
|
if ($info->getStatusCode() == 200) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2022-01-13 19:02:07 +08:00
|
|
|
$service->service->register($config['config']);
|
2022-01-13 18:25:29 +08:00
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
2022-01-13 18:25:29 +08:00
|
|
|
* @throws Exception
|
2022-01-09 14:00:32 +08:00
|
|
|
*/
|
|
|
|
|
public function tick(): void
|
|
|
|
|
{
|
2022-01-13 18:42:42 +08:00
|
|
|
try {
|
2022-05-31 11:02:15 +08:00
|
|
|
$this->reRegister();
|
2022-01-13 18:42:42 +08:00
|
|
|
} catch (\Throwable $throwable) {
|
2022-02-23 16:32:08 +08:00
|
|
|
$this->logger->error(error_trigger_format($throwable));
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
|
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
|
|
|
|
* @param $serviceName
|
2022-03-02 15:15:36 +08:00
|
|
|
* @return array|null
|
2022-01-09 14:00:32 +08:00
|
|
|
*/
|
2022-03-02 15:15:36 +08:00
|
|
|
public function getServices($serviceName): ?array
|
2022-01-09 14:00:32 +08:00
|
|
|
{
|
2022-03-02 15:15:36 +08:00
|
|
|
$lists = $this->health->setQuery('passing=true')->service($serviceName);
|
|
|
|
|
if ($lists->getStatusCode() != 200) {
|
|
|
|
|
return null;
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-03-02 15:15:36 +08:00
|
|
|
$body = json_decode($lists->getBody(), true);
|
|
|
|
|
if (empty($body)) {
|
|
|
|
|
return null;
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-03-02 15:15:36 +08:00
|
|
|
return array_column($body, 'Service');
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
|
|
|
|
* @param string $name
|
|
|
|
|
* @param string $class
|
|
|
|
|
* @param array $serviceConfig
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function add(string $name, string $class, array $serviceConfig): bool
|
|
|
|
|
{
|
|
|
|
|
if (!isset($this->_rpc[$name])) {
|
2022-05-31 10:53:33 +08:00
|
|
|
// $this->_rpc[$name] = ['id' => $serviceConfig['ID'], 'config' => $serviceConfig];
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-03-02 16:27:15 +08:00
|
|
|
Router::addServer('rpc', static function () use ($name, $class) {
|
|
|
|
|
Router::get($name, $class);
|
|
|
|
|
});
|
2022-01-09 14:00:32 +08:00
|
|
|
return true;
|
|
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function doneList(): array
|
|
|
|
|
{
|
|
|
|
|
$array = [];
|
|
|
|
|
foreach ($this->_rpc as $list) {
|
|
|
|
|
$array[] = $list;
|
|
|
|
|
}
|
|
|
|
|
return $array;
|
|
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
/**
|
2022-05-31 10:53:33 +08:00
|
|
|
* @return void
|
|
|
|
|
* @throws Kiri\Exception\ConfigException
|
2022-01-09 14:00:32 +08:00
|
|
|
*/
|
2022-05-31 10:53:33 +08:00
|
|
|
public function register(): void
|
2022-01-09 14:00:32 +08:00
|
|
|
{
|
2022-01-11 14:41:06 +08:00
|
|
|
$agent = Kiri::getDi()->get(Agent::class);
|
2022-05-31 10:53:33 +08:00
|
|
|
|
|
|
|
|
$list = Config::get("rpc.consul", null, true);
|
|
|
|
|
|
|
|
|
|
$agent->service->deregister($list['ID']);
|
|
|
|
|
$data = $agent->service->register($list);
|
|
|
|
|
if ($data->getStatusCode() != 200) {
|
|
|
|
|
$this->logger->error($data->getBody());
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|
2022-05-31 10:53:33 +08:00
|
|
|
|
2022-01-09 14:00:32 +08:00
|
|
|
}
|