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

C#实现Nginx平滑加权轮询算法,第1张

概述本文实例为大家分享了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<sum; i++)    {      index = NextServerIndex(sv);      Console.Writeline("{0}{1}",sv[index].name,sv[index].Weight);    }    Console.Read();  }

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

您可能感兴趣的文章:c# 实现轮询算法实例代码 总结

以上是内存溢出为你收集整理的C#实现Nginx平滑加权轮询算法全部内容,希望文章能够帮你解决C#实现Nginx平滑加权轮询算法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/langs/1253201.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存