欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 詳解Nginx輪詢算法底層實現(xiàn)的方法

詳解Nginx輪詢算法底層實現(xiàn)的方法

熱門標(biāo)簽:菏澤自動電銷機(jī)器人公司 網(wǎng)絡(luò)電話外呼系統(tǒng)開發(fā) 滴滴急救中心地圖標(biāo)注 福州語音電銷機(jī)器人招商 外呼線路隨意切換嗎 北海智能電銷機(jī)器人公司 艾澤拉斯地圖標(biāo)注 申請400電話收費(fèi)標(biāo) 淘寶辦理400電話是多少

輪詢算法簡介

在工作中很多人都使用到了nginx,對nginx得配置也是爛熟于心,今天我主要想介紹一下nginx輪詢算法得幾種底層實現(xiàn)方式。

簡單輪詢算法

這種算法比較簡單,舉個例子就是你有三臺服務(wù)器

第一臺服務(wù)器 192.168.1.1
第二臺服務(wù)器 192.168.1.2
第三臺服務(wù)器 192.168.1.3

第一個請求過來之后默認(rèn)訪問第一臺,第二個請求過來訪問第二臺,第三次請求過來訪問第三臺,第四次請求過來訪問第一臺,以此類推。以下是我代碼實現(xiàn)簡單得算法:

public class SimplePolling {

  /**
   * key是ip
   */
  public static List <String> ipService = new LinkedList <>();
  static {
    ipService.add("192.168.1.1");
    ipService.add("192.168.1.2");
    ipService.add("192.168.1.3");
  }
  public static int pos = 0;
  public static String getIp(){
    if(pos >= ipService.size()){
      //防止索引越界
      pos = 0;
    }
    String ip = ipService.get(pos);
    pos ++;
    return ip;

  }

  public static void main(String[] args) {
    for (int i = 0; i < 4; i++) {
      System.out.println(getIp());

    }
  }
}

模擬執(zhí)行4次執(zhí)行結(jié)果是


此時如果我有一臺服務(wù)器性能比較好(比如192.168.1.1),我想讓這臺服務(wù)器處理多一點請求,此時就涉及到了權(quán)重得概率,這種算法就不能實現(xiàn),請看我后面描述的輪詢升級版算法。

加權(quán)輪詢算法

此時我需要把我前面3臺服務(wù)器都設(shè)置權(quán)重,比如第一臺設(shè)置5,第二臺設(shè)置1,第三臺設(shè)置1

第一臺服務(wù)器 192.168.1.1 5
第二臺服務(wù)器 192.168.1.2 1
第三臺服務(wù)器 192.168.1.3 1

此時前5個請求都會訪問到第一臺服務(wù)器,第六個請求會訪問到第二臺服務(wù)器,第七個請求會訪問到第三臺服務(wù)器。

以下是我給出的代碼案例:

public class WeightPolling {

  /**
   * key是ip,value是權(quán)重
   */
  public static Map<String, Integer> ipService = new LinkedHashMap<>();
  static {
    ipService.put("192.168.1.1", 5);
    ipService.put("192.168.1.2", 1);
    ipService.put("192.168.1.3", 1);
  }
  public static int requestId = 0;
  public static int getAndIncrement() {
    return requestId++;
  }

  public static String getIp(){
    //獲取總的權(quán)重
    int totalWeight =0;
    for (Integer value : ipService.values()) {
      totalWeight+= value;
    }
    //獲取當(dāng)前輪詢的值
    int andIncrement = getAndIncrement();
    int pos = andIncrement% totalWeight;
    for (String ip : ipService.keySet()) {
      if(pos < ipService.get(ip)){
        return ip;
      }
      pos -= ipService.get(ip);
    }
    return null;
  }

  public static void main(String[] args) {
    for (int i = 0; i < 7; i++) {
      System.out.println(getIp());
    }
  }

}

此時運(yùn)行結(jié)果是


可以看的第一臺服務(wù)器執(zhí)行了5次,后面2臺依次執(zhí)行一次,依次類推。可能你覺得這種算法還不錯。其實這種算法有一個缺點是,如果我第一臺服務(wù)器設(shè)置權(quán)重過大可能我需要很多次請求都執(zhí)行到第一臺服務(wù)器上去,這樣的情況分布是不均勻的,會造成某一臺服務(wù)器壓力過大導(dǎo)致崩潰。所以我后面要引入第三種算法來解決這個問題

平滑加權(quán)輪詢算法

這種算法可能比較復(fù)雜,我第一次看也有點不太明白,后面看過相關(guān)資料在結(jié)合我自己的理解給大家圖文解釋一下,這里我舉例的服務(wù)器配置和權(quán)重還是和上面一樣

請求 當(dāng)前權(quán)重 = 自身權(quán)重+選中后當(dāng)前權(quán)重 總權(quán)重 當(dāng)前最大權(quán)重 返回的ip 選中后當(dāng)前權(quán)重=當(dāng)前最大權(quán)重-總權(quán)重
1 {5,1,1} 7 5 192.168.1.1 {-2,1,1}
2 {3,2,2} 7 3 192.168.1.1 {-4,2,2}
3 {1,3,3} 7 3 192.168.1.2 {1,-4,3}
4 {6,-3,4} 7 6 192.168.1.1 {-1,-3,4}
5 {4,-2,5} 7 5 192.168.1.3 {4,-2,-2}
6 {9,-1,-1} 7 9 192.168.1.1 {2,-1,-1}
7 {7,0,0} 7 7 192.168.1.1 {0,0,0}

由上圖可以看出第一臺服務(wù)器雖然權(quán)重設(shè)置的是5,但并不是第五次請求過來都是第一臺服務(wù)器執(zhí)行,而是分散執(zhí)行,調(diào)度序列是非常均勻的,且第 7 次調(diào)度時選中后當(dāng)前權(quán)重又回到 {0, 0, 0},實例的狀態(tài)同初始狀態(tài)一致,所以后續(xù)可以一直重復(fù)調(diào)度操作。

可能有的人還不能清楚的明白上一張圖表示的含義,我這里大概描述一下:

1.首先總權(quán)重不會變,默認(rèn)就是當(dāng)前設(shè)置的權(quán)重之和

2.在第一次請求進(jìn)來的時候我默認(rèn)初始化當(dāng)前權(quán)重選中值是{0,0,0},所以當(dāng)前權(quán)重的值就是{5+0,1+0,1+0},這里的5,1,1就是我們前面每臺服務(wù)器設(shè)置的權(quán)重。

3.這里我們可以得出第一次請求過來的最大權(quán)重是5。然后返回第一臺服務(wù)器ip

4.然后我們設(shè)置選中后當(dāng)前權(quán)重,這里就是當(dāng)前最大權(quán)重減去總權(quán)重(5-7),沒有選中的權(quán)重不變,這時候得到當(dāng)前權(quán)重選中權(quán)重的值{5-7,1,1}

5.在第二次請求過來的時候我們延續(xù)上面的2,3,4步驟執(zhí)行.

如果這里還有不懂得我下面會提供我自己用java代碼實現(xiàn)的算法:

public class Polling {

  /**
   * key是ip,value是權(quán)重
   */
  public static Map <String,Integer> ipService = new LinkedHashMap <>();
  static {
    ipService.put("192.168.1.1",5);
    ipService.put("192.168.1.2",1);
    ipService.put("192.168.1.3",1);
  }
  private static Map<String,Weight> weightMap = new LinkedHashMap <>();

  public static String getIp(){
    //計算總的權(quán)重
     int totalWeight = 0;
    for (Integer value : ipService.values()) {
      totalWeight+=value;
    }
    //首先判斷weightMap是否為空
    if(weightMap.isEmpty()){
      ipService.forEach((ip,weight)->{
        Weight weights = new Weight(ip, weight,0);
        weightMap.put(ip,weights);
      });
    }
    //給map中得對象設(shè)置當(dāng)前權(quán)重
    weightMap.forEach((ip,weight)->{
      weight.setCurrentWeight(weight.getWeight() + weight.getCurrentWeight());
    });

    //判斷最大權(quán)重是否大于當(dāng)前權(quán)重,如果為空或者小于當(dāng)前權(quán)重,則把當(dāng)前權(quán)重賦值給最大權(quán)重
    Weight maxWeight = null;
    for (Weight weight : weightMap.values()) {
      if(maxWeight ==null || weight.getCurrentWeight() > maxWeight.getCurrentWeight()){
        maxWeight = weight;
      }
    }
    //最后把當(dāng)前最大權(quán)重減去總的權(quán)重
    maxWeight.setCurrentWeight(maxWeight.getCurrentWeight() - totalWeight);
    //返回
    return maxWeight.getIp();
  }

  public static void main(String[] args) {
    //模擬輪詢7次取ip
    for (int i = 0; i < 7; i++) {
      System.out.println(getIp());
    }
  }

}

class Weight{
  /**
   * ip
   */
  private String ip;
  /**
   * 設(shè)置得權(quán)重
   */
  private int weight;
  /**
   * 當(dāng)前權(quán)重
   */
  private int currentWeight;

  public Weight(String ip, int weight,int currentWeight) {
    this.ip = ip;
    this.weight = weight;
    this.currentWeight = currentWeight;
  }

  public String getIp() {
    return ip;
  }

  public void setIp(String ip) {
    this.ip = ip;
  }

  public int getWeight() {
    return weight;
  }

  public void setWeight(int weight) {
    this.weight = weight;
  }

  public int getCurrentWeight() {
    return currentWeight;
  }

  public void setCurrentWeight(int currentWeight) {
    this.currentWeight = currentWeight;
  }
}

這里代碼得執(zhí)行結(jié)果是:


可以看出此處執(zhí)行結(jié)果和表格里描述得結(jié)果一致。

總結(jié)

可能第三種算法理解起來有點復(fù)雜,如果看不懂圖表得意思可以先執(zhí)行下代碼,debugger一步步調(diào)試后還是很好理解。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:亳州 丹東 延安 混顯 滄州 三沙 賀州 資陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Nginx輪詢算法底層實現(xiàn)的方法》,本文關(guān)鍵詞  詳解,Nginx,輪詢,算法,底層,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Nginx輪詢算法底層實現(xiàn)的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解Nginx輪詢算法底層實現(xiàn)的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    欧美精选在线播放| 男女全黄做爰文章| 国内不卡的二区三区中文字幕| 欧美日韩亚洲国产综合| 五月天激情丁香| 老妇女50岁三级| 色菇凉天天综合网| 欧美视频在线播放| 欧美日韩亚洲高清一区二区| 3d动漫精品啪啪1区2区免费| 欧美人体做爰大胆视频| 日韩一级视频免费观看在线| 日韩欧美卡一卡二| 国产三级精品三级| 亚洲欧洲精品成人久久奇米网| 亚洲欧美日韩中文字幕一区二区三区| 国产精品国产三级国产普通话蜜臀| 国产精品伦一区二区三级视频| 最新久久zyz资源站| 一区二区三区四区视频精品免费 | 日韩影院一区二区| 色欧美日韩亚洲| 欧美一区国产二区| 久久青草欧美一区二区三区| 国产精品日产欧美久久久久| 亚洲午夜精品久久久久久久久| 免费观看成人av| 成人精品视频一区二区三区| 成人啪啪18免费游戏链接| 欧美日韩亚洲综合一区二区三区| 欧美日韩一区小说| 国产精品网站在线| 日韩综合小视频| av午夜一区麻豆| 亚洲第一成人网站| 欧美三级日韩三级国产三级| 久久久久久久久久久久久夜| 亚洲二区在线视频| 国产**成人网毛片九色| 一级黄色片大全| 91精品国产综合久久精品| 国产精品毛片无遮挡高清| 免费成人结看片| 性高潮免费视频| 欧洲亚洲国产日韩| 中文字幕乱码日本亚洲一区二区| 天天综合天天做天天综合| 91亚洲永久精品| 日本青青草视频| 中文字幕第一区| 国内外成人在线视频| 星空大象在线观看免费播放| 欧美性淫爽ww久久久久无| 国产精品久久久久久户外露出 | 在线播放av网址| 一本色道**综合亚洲精品蜜桃冫| 久久精品男人天堂av| 国模冰冰炮一区二区| 久久久久久亚洲中文字幕无码| 56国语精品自产拍在线观看| 亚洲成人精品一区二区| 97人妻精品一区二区三区免费| 欧美手机在线视频| 午夜日韩在线电影| 黄色网址在线视频| 欧美精品一区二区精品网| 91精品在线观看入口| 亚洲综合在线视频| 稀缺呦国内精品呦| 日韩视频免费观看高清完整版| 免费高清不卡av| 国产破处视频在线观看| 国产精品少妇自拍| 91丨九色porny丨蝌蚪| 欧美日韩精品系列| 久久精品国产久精国产爱| 自拍偷拍你懂的| 亚洲人被黑人高潮完整版| 9191在线视频| 久久久精品欧美丰满| 成人爱爱电影网址| 欧美一区二区三区免费| 国产在线精品一区二区三区不卡 | 800av在线播放| 国产欧美日韩在线| 成人一区二区三区仙踪林| 精品国产乱码久久久久久1区2区| 丁香婷婷综合激情五月色| 欧美喷水一区二区| 粉嫩aⅴ一区二区三区四区五区| 欧美色偷偷大香| 国产福利精品一区| 欧美一区日韩一区| 99精品黄色片免费大全| 精品国产3级a| 麻豆短视频在线观看| 国产精品免费视频网站| 黄色aaa视频| 亚洲国产成人高清精品| 日本中文在线视频| 麻豆精品一区二区| 欧美精品久久一区二区三区| www.99精品| 久久久久国产免费免费| 一出一进一爽一粗一大视频| 成人欧美一区二区三区黑人麻豆 | 从欧美一区二区三区| 精品国偷自产国产一区| 中文字幕一区二区三区乱码不卡| 成人免费一区二区三区在线观看| 国产成人免费观看网站| 日本午夜精品视频在线观看| 91精品麻豆日日躁夜夜躁| 国产一区二区三区香蕉| 欧美系列日韩一区| 91在线免费播放| 日韩美女视频一区二区| 美女的奶胸大爽爽大片| 成人精品免费网站| 国产中文av在线| 国产精品一区二区黑丝| 国产亚洲自拍一区| 中文字幕乱码av| 成人av电影免费在线播放| 国产精品午夜在线| 色一情一伦一子一伦一区| 91视频一区二区| 天堂久久一区二区三区| 精品国产伦理网| 国产视频精品免费| 91视频91自| 午夜精彩视频在线观看不卡| 欧美一级片在线| 天天躁夜夜躁狠狠是什么心态| 精品在线一区二区| 中文字幕综合网| 日韩三级免费观看| 亚洲一级理论片| 国产黄色一区二区三区| 免费欧美在线视频| 国产精品欧美极品| 在线成人高清不卡| 国产精品视频在| 四虎国产精品永久免费观看视频| 日本不卡在线视频| 国产精品不卡一区二区三区| 欧美色综合久久| 精品丰满少妇一区二区三区| 91丝袜美女网| 久久成人久久爱| 亚洲精品v日韩精品| 久久精品亚洲精品国产欧美kt∨| 在线视频国内自拍亚洲视频| 美女爆乳18禁www久久久久久| av不卡在线观看| 国产美女一区二区| 亚洲影院免费观看| 亚洲欧美在线视频观看| 久久久亚洲综合| 日韩一级高清毛片| 欧美在线观看视频一区二区| 国产免费嫩草影院| 插吧插吧综合网| 中文字幕乱码在线| 年下总裁被打光屁股sp | 国产亚洲人成网站| 欧美一区二区三区视频免费播放| 色94色欧美sute亚洲线路二| 五月综合色婷婷| 亚洲一区电影在线观看| 三上悠亚ssⅰn939无码播放| 欧美成人精品一区二区综合免费| 91在线观看视频| 91网站在线观看视频| av在线这里只有精品| av一区二区三区| 99久久综合精品| 91一区在线观看| 日本黄色www| 污污免费在线观看| 制服丝袜第一页在线观看| 蜜臀av粉嫩av懂色av| 日本xxxx裸体xxxx| 欧洲美一区二区三区亚洲| 亚洲av无码一区二区二三区| 91在线视频官网| 国产91精品在线观看| 粉嫩一区二区三区在线看| www.66久久| 无码人妻一区二区三区精品视频| 91精产国品一二三| 中文字幕精品视频在线| 美女爆乳18禁www久久久久久| av在线播放中文字幕| 国产大学生自拍| 日韩一区和二区| 国产欧美一区二区三区网站| 亚洲欧美日韩国产成人精品影院| 亚洲线精品一区二区三区| 美女网站在线免费欧美精品|