songlijian / php-apollo-client
PHP Apollo 客户端
1.0.0
2019-05-06 03:43 UTC
Requires
- php: ~7.0
This package is auto-updated.
Last update: 2024-09-06 17:26:32 UTC
README
PHP 版本 >= 7.0
$ composer require songlijian/php-apollo-client
特性
- 支持实时获取 Apollo 配置变更
- 支持拉取配置后的自定义回调处理
用法
客户端以 CLI 方式后台启动执行,支持 Apollo 配置的实时获取,并将配置保存在指定目录以供应用程序读取解析
客户端示例代码
#!/usr/bin/env php <?php require 'vender/autoload.php'; // autoload use Org\Multilinguals\Apollo\Client\ApolloClient; //specify address of apollo server $server = getenv('CONFIG_SERVER'); // get server address from env //specify your appid at apollo config server $appid = getenv('APPID'); // get appid from env //specify namespaces of appid at apollo config server $namespaces = getenv('NAMESPACE'); // get namespaces from env $namespaces = explode(',', $namespaces); $apollo = new ApolloClient($server, $appid, $namespaces); if ($clientIp = getenv('CLIENTIP')) { $apollo->setClientIp($clientIp); } ini_set('memory_limit','128M'); $pid = getmypid(); echo "start [$pid]\n"; $restart = true; //auto start if failed do { $error = $apollo->start(); if ($error) echo('error:'.$error."\n"); }while($error && $restart);
配置管理
拉取的配置默认保存在脚本所在目录,每个 namespace 的配置以 apolloConfig.{$namespaceName}.php
的方式命名保存
Docker 环境客户端自启动
在 Docker 的启动脚本中加入启动代码,一般的 PHP 容器启动脚本为 docker-php-entrypoint
if [ -f "/path/to/start.php" ]; then apollo_ps=$(ps -aux | grep -c "php /path/to/start.php") if [ $apollo_ps -eq 1 ]; then php /path/to/start.php & fi fi