婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Nginx輪詢算法底層實現的方法

詳解Nginx輪詢算法底層實現的方法

熱門標簽:菏澤自動電銷機器人公司 網絡電話外呼系統開發 滴滴急救中心地圖標注 福州語音電銷機器人招商 外呼線路隨意切換嗎 北海智能電銷機器人公司 艾澤拉斯地圖標注 申請400電話收費標 淘寶辦理400電話是多少

輪詢算法簡介

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

簡單輪詢算法

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

第一臺服務器 192.168.1.1
第二臺服務器 192.168.1.2
第三臺服務器 192.168.1.3

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

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());

    }
  }
}

模擬執行4次執行結果是


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

加權輪詢算法

此時我需要把我前面3臺服務器都設置權重,比如第一臺設置5,第二臺設置1,第三臺設置1

第一臺服務器 192.168.1.1 5
第二臺服務器 192.168.1.2 1
第三臺服務器 192.168.1.3 1

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

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

public class WeightPolling {

  /**
   * key是ip,value是權重
   */
  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(){
    //獲取總的權重
    int totalWeight =0;
    for (Integer value : ipService.values()) {
      totalWeight+= value;
    }
    //獲取當前輪詢的值
    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());
    }
  }

}

此時運行結果是


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

平滑加權輪詢算法

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

請求 當前權重 = 自身權重+選中后當前權重 總權重 當前最大權重 返回的ip 選中后當前權重=當前最大權重-總權重
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}

由上圖可以看出第一臺服務器雖然權重設置的是5,但并不是第五次請求過來都是第一臺服務器執行,而是分散執行,調度序列是非常均勻的,且第 7 次調度時選中后當前權重又回到 {0, 0, 0},實例的狀態同初始狀態一致,所以后續可以一直重復調度操作。

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

1.首先總權重不會變,默認就是當前設置的權重之和

2.在第一次請求進來的時候我默認初始化當前權重選中值是{0,0,0},所以當前權重的值就是{5+0,1+0,1+0},這里的5,1,1就是我們前面每臺服務器設置的權重。

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

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

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

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

public class Polling {

  /**
   * key是ip,value是權重
   */
  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(){
    //計算總的權重
     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中得對象設置當前權重
    weightMap.forEach((ip,weight)->{
      weight.setCurrentWeight(weight.getWeight() + weight.getCurrentWeight());
    });

    //判斷最大權重是否大于當前權重,如果為空或者小于當前權重,則把當前權重賦值給最大權重
    Weight maxWeight = null;
    for (Weight weight : weightMap.values()) {
      if(maxWeight ==null || weight.getCurrentWeight() > maxWeight.getCurrentWeight()){
        maxWeight = weight;
      }
    }
    //最后把當前最大權重減去總的權重
    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;
  /**
   * 設置得權重
   */
  private int weight;
  /**
   * 當前權重
   */
  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;
  }
}

這里代碼得執行結果是:


可以看出此處執行結果和表格里描述得結果一致。

總結

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:亳州 丹東 延安 混顯 滄州 三沙 賀州 資陽

巨人網絡通訊聲明:本文標題《詳解Nginx輪詢算法底層實現的方法》,本文關鍵詞  詳解,Nginx,輪詢,算法,底層,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Nginx輪詢算法底層實現的方法》相關的同類信息!
  • 本頁收集關于詳解Nginx輪詢算法底層實現的方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    一区二区三区四区不卡视频| 中文字幕一区av| 国产成人综合在线| 国产在线日韩欧美| 成人手机在线视频| 91蝌蚪porny九色| 欧美日韩国产精品成人| 精品国产自在久精品国产| 国产蜜臀97一区二区三区| 亚洲欧洲三级电影| 日韩二区三区四区| 国产精品一线二线三线精华| 91香蕉视频mp4| 日韩欧美在线综合网| 中文一区在线播放| 天堂久久久久va久久久久| 国产在线不卡一区| 在线观看视频一区| 久久综合九色综合欧美就去吻| 亚洲欧美激情在线| 国产麻豆精品视频| 欧美日韩综合一区| 国产精品久久一级| 久久国产精品无码网站| 色综合天天狠狠| 欧美成人精品二区三区99精品| 国产精品不卡在线| 国产综合久久久久久鬼色| 欧美丝袜第三区| 国产三级欧美三级| 婷婷久久综合九色国产成人 | 国产成人在线观看免费网站| 在线免费观看不卡av| 久久久久久麻豆| 免费视频一区二区| 欧美日韩黄色一区二区| 亚洲日本在线a| 国产99久久久国产精品免费看| 日韩视频中午一区| 亚洲成av人片在线| 欧美在线短视频| 亚洲男人的天堂一区二区| 国产99精品国产| 国产精品丝袜久久久久久app| 国内精品伊人久久久久影院对白| 99久久精品免费看国产免费软件| 中文字幕一区二区三区不卡在线| 久久91精品久久久久久秒播| 欧美网站一区二区| 国产精品黄色在线观看| 国产激情视频一区二区三区欧美| 欧美巨大另类极品videosbest| 亚洲欧美aⅴ...| 91亚洲精品久久久蜜桃| 国产精品久久久一区麻豆最新章节| 久久99国内精品| 精品精品国产高清一毛片一天堂| 久久精品免费看| 精品日韩一区二区三区| 久久99在线观看| 精品精品欲导航| 韩国精品主播一区二区在线观看| 日韩一区二区三区精品视频| 日本强好片久久久久久aaa| 欧美精品18+| 理论电影国产精品| 精品福利在线导航| 国内精品伊人久久久久av一坑 | 久久精品国产免费| 亚洲精品一线二线三线无人区| 国产又粗又猛又爽又黄91精品| 精品久久人人做人人爰| 国产在线一区二区| 国产精品免费久久| 色婷婷av一区二区三区大白胸| 亚洲图片自拍偷拍| 在线播放91灌醉迷j高跟美女 | 欧美亚洲一区二区在线观看| 亚洲狠狠爱一区二区三区| 69久久99精品久久久久婷婷| 韩国女主播一区| 日韩一区在线看| 欧美日韩视频在线一区二区| 青椒成人免费视频| 国产欧美精品一区aⅴ影院 | 国产综合成人久久大片91| 国产精品视频一二| 欧美色中文字幕| 国产米奇在线777精品观看| 中文字幕一区av| 日韩一二三四区| 成人app软件下载大全免费| 亚洲精品乱码久久久久久| 日韩免费一区二区| 91蝌蚪国产九色| 黄色小说综合网站| 亚洲黄色免费电影| 精品国产伦一区二区三区免费| 99精品在线观看视频| 欧美96一区二区免费视频| 国产精品嫩草久久久久| 欧美在线制服丝袜| 国产精品一区免费视频| 亚洲自拍偷拍麻豆| 国产欧美在线观看一区| 91麻豆精品国产91久久久久| 成人性生交大片| 日韩精品一二三| 一区二区三区在线视频观看58| 精品久久国产老人久久综合| 欧美影片第一页| 成人免费视频播放| 精品一区二区精品| 午夜成人免费电影| 亚洲精品久久久蜜桃| 国产午夜精品福利| 宅男噜噜噜66一区二区66| 色中色一区二区| 成人av在线影院| 国产成人午夜99999| 玖玖九九国产精品| 日本va欧美va瓶| 亚洲成人精品一区二区| 亚洲婷婷综合色高清在线| 国产拍揄自揄精品视频麻豆| 欧美大尺度电影在线| 欧美裸体一区二区三区| 在线精品视频一区二区三四| 91欧美一区二区| 91网上在线视频| www.日韩在线| 国产69精品久久777的优势| 国产美女一区二区三区| 美女视频免费一区| 亚洲激情中文1区| 9人人澡人人爽人人精品| 激情五月婷婷综合| 蜜臀av性久久久久蜜臀aⅴ| 日韩激情一二三区| 午夜电影网一区| 久久精品国产精品亚洲红杏| 9191成人精品久久| 欧美日韩精品一区二区三区| 在线观看视频一区| 日本三级亚洲精品| 午夜精品久久久久久不卡8050| 亚洲精品国久久99热| 国产精品久久久久久户外露出 | 精品999久久久| 精品免费视频一区二区| 日韩欧美在线观看一区二区三区| 3d动漫精品啪啪一区二区竹菊 | 一本到不卡精品视频在线观看| 成人a免费在线看| av成人免费在线观看| 色系网站成人免费| 在线观看91视频| 亚洲欧美成人一区二区三区| 精品国产区一区| 欧美一区永久视频免费观看| 精品国产乱码久久久久久1区2区| 国产一区二区三区视频在线播放| 精品中文字幕一区二区| 久久精品国产免费| 国产毛片精品视频| 99久久综合99久久综合网站| 一本色道久久加勒比精品 | 日韩电影免费在线看| 麻豆成人在线观看| 国产一区二区女| www.久久精品| 精品1区2区3区| 欧美精品一区在线观看| 国产精品丝袜91| 午夜欧美2019年伦理| 狠狠色丁香婷婷综合久久片| 成人精品视频.| 欧美色涩在线第一页| 日韩小视频在线观看专区| 国产日韩欧美电影| 亚洲一区二区三区四区在线观看 | 色国产综合视频| 性久久久久久久久| 麻豆精品在线观看| 成人午夜视频在线观看| 在线观看成人免费视频| 日韩一区二区电影| 日韩美女啊v在线免费观看| 亚洲一区二区四区蜜桃| 国产又黄又大久久| 91国产成人在线| 欧美一区二区在线免费观看| 中文字幕av一区二区三区免费看| 亚洲福利一区二区三区| 国产美女久久久久| 欧美男生操女生| 中文字幕在线不卡国产视频| 美女www一区二区| 色综合久久99| 国产日产亚洲精品系列|