平滑 加权轮询java,C#实现Nginx平滑加权轮询算法

本文实例为大家分享了C#实现Nginx平滑加权轮询算法的具体代码,供大家参考,具体内容如下

代码很简单,算法很经典!

1. 定义实体类

public struct ServerConfig

{

//初始权重

public int Weight {get;set;}

//当前权重

public int Current {get;set;}

//服务名称

public string Name {get;set;}

}

2. 算法

public static int NextServerIndex(ServerConfig[] serverConfigArray)

{

int index = -1;

int total = 0;

int size = serverConfigArray.Count();

for(int i = 0; i< size; i++)

{

serverConfigArray[i].Current += serverConfigArray[i].Weight;

total += serverConfigArray[i].Weight;

if (index == -1 || serverConfigArray[index].Current < serverConfigArray[i].Current)

{

index = i;

}

}

serverConfigArray[index].Current -= total;

return index;

}

3.调用

static void Main(string[] args)

{

var sv = new ServerConfig[] {

new ServerConfig{Name="A", Weight = 4},

new ServerConfig{Name="B", Weight = 2},

new ServerConfig{Name="C", Weight = 1}

};

int index = 0;

int sum = sv.Sum(m => m.Weight);

for(int i=0; i

{

index = NextServerIndex(sv);

Console.WriteLine("{0}{1}", sv[index].Name, sv[index].Weight);

}

Console.Read();

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值