mirror of
https://gitee.com/hyperf/hyperf.git
synced 2024-12-01 03:08:06 +08:00
3.6 KiB
3.6 KiB
Nacos
一個 Nacos
的 PHP
協程客户端,與 Hyperf
的配置中心、微服務治理完美結合。
安裝
composer require hyperf/nacos
發佈配置文件
php bin/hyperf.php vendor:publish hyperf/nacos
目錄結構
./src
├── Api
│ ├── AbstractNacos.php
│ ├── NacosConfig.php
│ ├── NacosInstance.php
│ ├── NacosOperator.php
│ └── NacosService.php
├── Client.php
├── Config
│ ├── FetchConfigProcess.php
│ ├── OnPipeMessageListener.php
│ └── PipeMessage.php
├── ConfigProvider.php
├── Contract
│ └── LoggerInterface.php
├── Exception
│ ├── InvalidArgumentException.php
│ ├── NacosThrowable.php
│ └── RuntimeException.php
├── Instance.php
├── Listener
│ ├── MainWorkerStartListener.php
│ └── OnShutdownListener.php
├── Model
│ ├── AbstractModel.php
│ ├── ConfigModel.php
│ ├── InstanceModel.php
│ └── ServiceModel.php
├── Process
│ └── InstanceBeatProcess.php
└── Service.php
服務與實例
MainWorkerStartListener.php
將在系統啟動完成時自動完成 實例註冊
,服務註冊
如果需要在服務下線時自動註銷服務,請增加如下配置,以監聽 Shutdown
事件
// config/autoload/server.php
return [
// ...other
'callbacks' => [
// ...other
SwooleEvent::ON_SHUTDOWN => [Hyperf\Framework\Bootstrap\ShutdownCallback::class, 'onShutdown']
]
];
獲取當前實例
use Hyperf\Utils\ApplicationContext;
use Hyperf\Nacos\Instance;
$container = ApplicationContext::getContainer();
$instance = $container->get(Instance::class);
獲取當前服務
use Hyperf\Utils\ApplicationContext;
use Hyperf\Nacos\Service;
$container = ApplicationContext::getContainer();
$service = $container->get(Service::class);
獲取一個服務的最優節點
use Hyperf\Utils\ApplicationContext;
use Hyperf\Nacos\Instance;
$container = ApplicationContext::getContainer();
$instance = $container->get(Instance::class);
$service = new ServiceModel([
'service_name' => 'hyperf',
'group_name' => 'api',
'namespace_id' => '5ce9d1c1-6732-4ccc-ae1f-5139af86a845'
]);
$optimal = $instance->getOptimal($service);
配置中心
MainWorkerStartListener.php
系統啟動時將拉取遠程配置, 併合入hyperf
的 Config
FetchConfigProcess.php
自定義進程將監聽配置, 若有更新將發送 PipeMessage
到各服務worker
進程, 併合入當前進程的 Config
如果服務如下配置
// config/autoload/nacos.php
return [
// ...other
'config_reload_interval' => 3,
// 遠程配置合併節點, 默認 config 根節點
'config_append_node' => 'nacos_config',
'listener_config' => [
// 配置項 dataId, group, tenant, type, content
[
'data_id' => 'hyperf-service-config',
'group' => 'DEFAULT_GROUP',
],
[
'data_id' => 'hyperf-service-config-yml',
'group' => 'DEFAULT_GROUP',
'type' => 'yml',
],
],
];
系統將自動監聽listener_config
中的配置,並將其合併入hyperf Config
對象的指定(config_append_node
) 節點,可以用config('nacos_config.***')
獲取,若沒有配置 config_append_node
項,將會併入 Config
對象根節點。
所有配置的
鍵(key)
在實際發起 API 請求時會自動從下劃線風格轉換為駝峯風格。