# 簡介 Hyperf 為您提供了分散式系統的外部化配置支援,預設適配了: - 由攜程開源的 [ctripcorp/apollo](https://github.com/ctripcorp/apollo),由 [hyperf/config-apollo](https://github.com/hyperf/config-apollo) 元件提供功能支援。 - 阿里雲提供的免費配置中心服務 [應用配置管理(ACM, Application Config Manager)](https://help.aliyun.com/product/59604.html),由 [hyperf/config-aliyun-acm](https://github.com/hyperf/config-aliyun-acm) 元件提供功能支援。 ## 為什麼要使用配置中心? 隨著業務的發展,微服務架構的升級,服務的數量、應用的配置日益增多(各種微服務、各種伺服器地址、各種引數),傳統的配置檔案方式和資料庫的方式已經可能無法滿足開發人員對配置管理的要求,同時對於配置的管理可能還會牽涉到 ACL 許可權管理、配置版本管理和回滾、格式驗證、配置灰度釋出、叢集配置隔離等問題,以及: - 安全性:配置跟隨原始碼儲存在版本管理系統中,容易造成配置洩漏 - 時效性:修改配置,需要每臺伺服器每個應用修改並重啟服務 - 侷限性:無法支援動態調整,例如日誌開關、功能開關等 因此,我們可以通過一個配置中心以一種科學的管理方式來統一管理相關的配置。 ## 安裝 ### Apollo ```bash composer require hyperf/config-apollo ``` ### Aliyun ACM ```bash composer require hyperf/config-aliyun-acm ``` ## 接入 Apollo 配置中心 如果您沒有對配置元件進行替換使用預設的 [hyperf/config](https://github.com/hyperf/config) 元件的話,接入 Apollo 配置中心則是輕而易舉,只需兩步。 - 通過 Composer 將 [hyperf/config-apollo](https://github.com/hyperf/config-apollo) ,即執行命令 `composer require hyperf/config-apollo` - 在 `config/autoload` 資料夾內增加一個 `apollo.php` 的配置檔案,配置內容如下 ```php true, // 是否使用獨立程序來拉取config,如果否則將在worker內以協程方式拉取 'use_standalone_process' => true, // Apollo Server 'server' => 'http://127.0.0.1:8080', // 您的 AppId 'appid' => 'test', // 當前應用所在的叢集 'cluster' => 'default', // 當前應用需要接入的 Namespace,可配置多個 'namespaces' => [ 'application', ], // 配置更新間隔(秒) 'interval' => 5, // 嚴格模式,當為 false 時,拉取的配置值均為 string 型別,當為 true 時,拉取的配置值會轉化為原配置值的資料型別 'strict_mode' => false, // 客戶端IP 'client_ip' => current(swoole_get_local_ip()), // 拉取配置超時時間 'pullTimeout' => 10, // 拉取配置間隔 'interval_timeout' => 60, ]; ``` ## 接入 Aliyun ACM 配置中心 接入 Aliyun ACM 配置中心與 Apollo 一樣都是輕而易舉的,同樣只需兩步。 - 通過 Composer 將 [hyperf/config-aliyun-acm](https://github.com/hyperf/config-aliyun-acm) ,即執行命令 `composer require hyperf/config-aliyun-acm` - 在 `config/autoload` 資料夾內增加一個 `aliyun_acm.php` 的配置檔案,配置內容如下 ```php true, // 是否使用獨立程序來拉取config,如果否則將在worker內以協程方式拉取 'use_standalone_process' => true, // 配置更新間隔(秒) 'interval' => 5, // 阿里雲 ACM 斷點地址,取決於您的可用區 'endpoint' => env('ALIYUN_ACM_ENDPOINT', 'acm.aliyun.com'), // 當前應用需要接入的 Namespace 'namespace' => env('ALIYUN_ACM_NAMESPACE', ''), // 您的配置對應的 Data ID 'data_id' => env('ALIYUN_ACM_DATA_ID', ''), // 您的配置對應的 Group 'group' => env('ALIYUN_ACM_GROUP', 'DEFAULT_GROUP'), // 您的阿里雲賬號的 Access Key 'access_key' => env('ALIYUN_ACM_AK', ''), // 您的阿里雲賬號的 Secret Key 'secret_key' => env('ALIYUN_ACM_SK', ''), ]; ``` ## 接入 Etcd 配置中心 - 安裝 `Etcd 客戶端` ``` composer require hyperf/etcd ``` - 新增 `Etcd 客戶端` 配置檔案 `etcd.php` ```php 'http://192.168.1.200:2379', 'version' => 'v3beta', 'options' => [ 'timeout' => 10, ], ]; ``` - 安裝 `Etcd 配置中心` ``` composer require hyperf/config-etcd ``` - 新增 `Etcd 配置中心` 配置檔案 `config_etcd.php` > mapping 為 `Etcd` 與 `Config` 的對映關係。對映中不存在的 `key`,則不會被同步到 `Config` 中。 ```php true, 'use_standalone_process' => true, 'namespaces' => [ '/test', ], 'mapping' => [ '/test/test' => 'etcd.test.test', ], 'interval' => 5, ]; ``` ## 配置更新的作用範圍 在預設的功能實現下,是由一個 `ConfigFetcherProcess` 程序根據配置的 `interval` 來向 Apollo 拉取對應 `namespace` 的配置,並通過 IPC 通訊將拉取到的新配置傳遞到各個 Worker 中,並更新到 `Hyperf\Contract\ConfigInterface` 對應的物件內。 需要注意的是,更新的配置只會更新 `Config` 物件,故僅限應用層或業務層的配置,不涉及框架層的配置改動,因為框架層的配置改動需要重啟服務,如果您有這樣的需求,也可以通過自行實現 `ConfigFetcherProcess` 來達到目的。 ## 注意事項 在命令列模式時,預設不會觸發事件分發,導致無法正常獲取到相關配置,可通過新增 `--enable-event-dispatcher` 引數來開啟。