No description, website, or topics provided.
Switch branches/tags
Nothing to show
Clone or download
Latest commit 0018e71 Dec 6, 2018
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
Robin 📝规范注释 Dec 6, 2018
Test 📝规范注释 Dec 6, 2018
.gitignore 初始化 Dec 3, 2018
Autoloader.php 增加namespace Dec 3, 2018
README.md 📝增加调度结果 Dec 4, 2018

README.md

负载均衡算法

介绍

用 PHP 实现几种负载均衡调度算法,详细见 负载均衡算法 系列。

预览图

调度算法

轮询

快速使用

use Robin\SmoothWeightedRobin;

require_once '/Autoloader.php';

// 加权轮询
$services = [
    '192.168.10.1:2202' => 5,
    '192.168.10.2:2202' => 1,
    '192.168.10.3:2202' => 1,
];

// 使用平滑加权算法
$robin = new SmoothWeightedRobin();
$robin->init($services);

$nodes = [];
for ($i = 1; $i <= 7; $i++) {
    $node = $robin->next();
    $nodes[$i] = $node;
}

//var_export(array_count_values($nodes));
var_export($nodes);

调度结果

使用平滑加权算法调度,会生成如下均匀序列:

'192.168.10.1:2202'
'192.168.10.1:2202'
'192.168.10.2:2202'
'192.168.10.1:2202'
'192.168.10.3:2202'
'192.168.10.1:2202'
'192.168.10.1:2202'