权重轮询调度算法(Weighted Round-Robin Scheduling)-C#实现
在多台机器实现负载均衡的时候,存在调度分配的问题.
如果服务器的配置的处理能力都一致的话,平均轮询分配可以直接解决问题,然而有些时候机器的处理能力是不一致的.
假如有2台机器 A和B , A的处理能力是B的2倍,则A的权重为2,B的权重为1.权值高的服务器先收到的连接,权值高的服 务器比权值低的服务器处理更多的连接,相同权值的服务器处理相同数目的连接数。
算法的C#版如下:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
namespace TestConsoleApplication
{
/// <summary>
/// 权重轮询算法
/// </summary>
public static class WeightedRoundRobin
{ private static List<Server> s = new List<Server>()
{
new Server()
{
IP = "192.168.0.100",
Weight =
},
new Server()
{
IP = "192.168.0.101",
Weight =
},
new Server()
{
IP = "192.168.0.102",
Weight =
},
new Server()
{
IP = "192.168.0.103",
Weight =
},
new Server()
{
IP = "192.168.0.104",
Weight =
},
}.OrderBy(a => a.Weight).ToList(); private static int i = -;//代表上一次选择的服务器
private static int gcd = GetGcd(s);//表示集合S中所有服务器权值的最大公约数
private static int cw = ;//当前调度的权值
private static int max = GetMaxWeight(s);
private static int n = s.Count;//服务器个数 /**
* 算法流程:
* 假设有一组服务器 S = {S0, S1, …, Sn-1} ,有相应的权重,变量I表示上次选择的服务器,1每次步长
* 权值cw初始化为0,i初始化为-1 ,当第一次的时候 权值取最大的那个服务器,
* 通过权重的不断递减 寻找 适合的服务器返回,直到轮询结束,权值返回为0
*/
public static Server GetServer()
{
while (true)
{
i = (i + ) % n;
if (i == )
{
cw = cw - gcd;
if (cw <= )
{
cw = max;
if (cw == )
return null;
}
}
if (s[i].Weight >= cw)
{
return s[i];
}
}
} /// <summary>
/// 获取服务器所有权值的最大公约数
/// </summary>
/// <param name="servers"></param>
/// <returns></returns>
private static int GetGcd(List<Server> servers)
{
return ;
}
/// <summary>
/// 获取最大的权值
/// </summary>
/// <param name="servers"></param>
/// <returns></returns>
private static int GetMaxWeight(List<Server> servers)
{
int max = ;
foreach (var s in servers)
{
if (s.Weight > max)
max = s.Weight;
}
return max;
}
}
/// <summary>
/// 服务器结构
/// </summary>
public class Server
{
public string IP;
public int Weight;
} class Program
{
static void Main(string[] args)
{
Dictionary<string, int> dic = new Dictionary<string, int>();
Server s;
for (int j = ; j < ; j++)
{
s = WeightedRoundRobin.GetServer();
Console.WriteLine("{0},weight:{1}", s.IP, s.Weight); if (!dic.Keys.Contains("服务器" + s.IP + ",权重:" + s.Weight))
dic.Add("服务器" + s.IP + ",权重:" + s.Weight, );
dic["服务器" + s.IP + ",权重:" + s.Weight]++;
} foreach (var i1 in dic)
{
Console.WriteLine("{0}共处理请求{1}次", i1.Key, i1.Value);
} Console.ReadLine();
}
}
运行结果:
运行100次的结果统计:
参考:http://en.wikipedia.org/wiki/Weighted_round_robin
权重轮询调度算法(Weighted Round-Robin Scheduling)-C#实现的更多相关文章
- 权重轮询调度算法 java版本号
权重轮询调度算法(Weighted Round-Robin Scheduling)--java版本号 因为每台server的配置.安装的业务应用等不同.其处理能力会不一样.所以,我们依据server的 ...
- 权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现2
权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现 ----参考Nginx中负载均衡算法实现 与上一遍博客 http://www.cnblogs.com/hu ...
- 权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现3
权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现3 之前两篇相关博文: 权重轮询调度算法(WeightedRound-RobinScheduling)-Ja ...
- 权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现
权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现 import java.math.BigInteger; import java.util.ArrayLi ...
- 权重轮询调度算法(WeightedRound-RobinScheduling)
权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现 ----参考Nginx中负载均衡算法实现 这里主要参考这篇文章的实现: Nginx 负载均衡-加权轮询策略 ...
- golang实现权重轮询调度算法
package main import ( "fmt" "time" ) var slaveDns = map[int]map[string]interface ...
- 通过 PowerShell 支持 Azure Traffic Manager 外部端点和权重轮询机制
Jonathan TulianiAzure网络 - DNS和 Traffic Manager高级项目经理 在北美 TechEd 大会上,我们宣布了 Azure Traffic Manager将支持 ...
- Nginx的负载均衡 - 加权轮询 (Weighted Round Robin) 下篇
Nginx版本:1.9.1 我的博客:http://blog.csdn.net/zhangskd 上篇blog讲述了加权轮询算法的原理.以及负载均衡模块中使用的数据结构,接着我们来看看加权轮询算法的具 ...
- Nginx的负载均衡 - 加权轮询 (Weighted Round Robin) 上篇
Nginx版本:1.9.1 我的博客:http://blog.csdn.net/zhangskd 算法介绍 来看一个简单的Nginx负载均衡配置. http { upstream cluster { ...
随机推荐
- css选择器分类
css选择器大致可以分为10大类: 1.元素选择器 如:p{} 2.类选择器 如:.xx{} 3.ID选择器 如:#xx{} 4.关联选择器 如:p a{} 5.子元素选择器 如:p>a{} 6 ...
- 轻松找回Win7桌面“消失”的IE9图标
打开注册表编辑器(Win+R打开运行窗口,运行regedit命令),依次展开到 [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion ...
- Objective-C中#define的常见用法
参考博客 http://blog.csdn.net/kindazrael/article/details/8108868 在C语言中,预处理代码是非常强大的工具,能让代码变得可读性和可维护性更强.预处 ...
- SQL 2008配置管理工具服务显示 远程过程调用失败0x800706be
摘自: http://www.cnblogs.com/cool-fire/archive/2012/09/15/2686131.html 基本上我的解决方案也是根据该文提示 操作的. 因为 我后来 装 ...
- poj2070
#include <stdio.h> int main(){ double a,b,c; int s; while(~scanf("%lf%lf%lf",&a, ...
- 001Linux命令
1.删除非空目录的命令:rm -rf [目录名],r表示迭代,f表示强制: 删除空目录:rmdir [目录名]: 删除文件:rm [文件名]: 2.用户管里类命令: (1)添加用户:useradd [ ...
- javscript处理XML DOM(待续)
1.加载并解析XML文件 function loadXMLFile(url){ var xmldoc if(window.ActiveXObject){ xmldoc = new ActiveXObj ...
- C#中使用官方驱动操作MongoDB
想要在C#中使用MongoDB,首先得要有个MongoDB支持的C#版的驱动.C#版的驱动有很多种,如官方提供的,samus. 实现思路大都类似.这里我们先用官方提供的mongo-csharp-dri ...
- Python pass 语句使用示例
Python pass 语句的使用方法示例.Python pass是空语句,pass语句什么也不做,一般作为占位符或者创建占位程序,是为了保持程序结构的完整性,pass语句不会执行任何操作,比如: P ...
- jQuery编写的一款兼容IE6的图片轮播幻灯片
jQuery编写的一款兼容IE6的图片轮播幻灯片,很不错的一款jquery特效.大家可以下载下来研究研究. 每隔几秒就自动切换一波图片,此效果兼容性还做的不错,适合居多的浏览器. 适用浏览器:IE6. ...