songlijian/php-apollo-client

PHP Apollo 客户端

1.0.0 2019-05-06 03:43 UTC

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