我使用的是这个库的修改版本(https://github.com/kamermans/HAProxyAPI)连接到我的所有负载平衡器实例。但是,要知道连接的服务器是活动实例还是备份实例,我需要从统计信息中寻址"bck"属性。(我无法使用$loadbalancer['haproxy_stats']->info->line->data->bck访问它)
注意这个属性:$loadbalancer['haproxy_stats']->health->backup。不是我需要的,这只指示此负载平衡器中是否存在备份服务器。
如何访问此属性?
示例Haproxy Stats来自:Haproxy Stats::get($exec)->getServiceStats($interface,$server);
结果(print_r)如下所示:
HAProxy _ Stats_Service对象([info]=>HAProxy _ Stats_Info对象([map:protected]=>大堆([pxname]=>代理名称[svname]=>服务名称[weight]=>重量[pid]=>process_id[iid]=>代理id[sid]=>service_id[tracked]=>跟踪[type]=>类型)
[type] => 2
[proxy_name] => core_loadbalancer
[service_name] => Core03
[process_id] => 1
[proxy_id] => 2
[service_id] => 3
[weight] => 1
[tracked] =>
[line:protected] => HAProxy_Stats_Line Object
(
[data:protected] => Array
(
[pxname] => core_loadbalancer
[svname] => Core03
[qcur] => 0
[qmax] => 0
[scur] => 0
[smax] => 0
[slim] => 20000
[stot] => 0
[bin] => 0
[bout] => 0
[dreq] =>
[dresp] => 0
[ereq] =>
[econ] => 0
[eresp] => 0
[wretr] => 0
[wredis] => 0
[status] => UP
[weight] => 1
[act] => 0
[bck] => 1
[chkfail] => 6
[chkdown] => 0
[lastchg] => 523133
[downtime] => 0
[qlimit] =>
[pid] => 1
[iid] => 2
[sid] => 3
[throttle] =>
[lbtot] => 0
[tracked] =>
[type] => 2
[rate] => 0
[rate_lim] =>
[rate_max] => 0
[check_status] => L4OK
[check_code] =>
[check_duration] => 0
[hrsp_1xx] => 0
[hrsp_2xx] => 0
[hrsp_3xx] => 0
[hrsp_4xx] => 0
[hrsp_5xx] => 0
[hrsp_other] => 0
[hanafail] => 0
[req_rate] =>
[req_rate_max] =>
[req_tot] =>
[cli_abrt] => 0
[srv_abrt] => 0
[] =>
)
)
)
对象继续,但有字符限制。。。
如果为它创建了一个问题,这个问题会很快得到解决,但迟做总比不做好。我想:)
这确实是正确的财产:
$loadbalancer['haproxy_stats']->health->backup
但是,如果您正在检查负载平衡器BACKEND的统计数据,它只会返回备份节点的数量。如果你想知道单个节点是活动的还是备份的,你需要像这样迭代它们:
foreach ($stats->getBackendNames() as $backend) {
foreach ($stats->getServerNames($backend) as $server) {
$service = $stats->getServiceStats($backend, $server);
echo "$backend:$server'n";
echo " Active: {$service->health->active}'n";
echo " Backup: {$service->health->backup}'n";
echo " Health: {$service->health->status}'n'n";
}
}
这将产生这样的输出:
foo-cloud:FRONTEND
Active:
Backup:
Health: OPEN
production-nodes:hiphop-node01-us.foocloud.com
Active: 1
Backup: 0
Health: UP
production-nodes:apache-node01-us.foocloud.com
Active: 0
Backup: 1
Health: UP
production-nodes:hiphop-node02-us.foocloud.com
Active: 1
Backup: 0
Health: UP
production-nodes:apache-node02-us.foocloud.com
Active: 0
Backup: 1
Health: MAINT
production-nodes:BACKEND
Active: 2
Backup: 2
Health: UP
stats:FRONTEND
Active:
Backup:
Health: OPEN
stats:BACKEND
Active: 0
Backup: 0
Health: UP