好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁(yè) > 知識(shí)庫(kù) > PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法分析

PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法分析

熱門(mén)標(biāo)簽:宿州正規(guī)外呼系統(tǒng)軟件 萍鄉(xiāng)商鋪地圖標(biāo)注 合肥企業(yè)外呼系統(tǒng)線(xiàn)路 代理打電話(huà)機(jī)器人 電信外呼系統(tǒng)多少錢(qián)一個(gè)月 桂陽(yáng)公司如何做地圖標(biāo)注 太原400電話(huà)申請(qǐng)流程 企業(yè)400電話(huà)辦理多少費(fèi)用 神龍斗士電話(huà)機(jī)器人

本文實(shí)例講述了PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法。分享給大家供大家參考,具體如下:

1. 負(fù)載均衡算法有哪些?

  • 輪詢(xún)法:將請(qǐng)求按順序輪流地分配到后端服務(wù)器上,它均衡地對(duì)待后端的每一臺(tái)服務(wù)器,而不關(guān)心服務(wù)器實(shí)際的連接數(shù)和當(dāng)前的系統(tǒng)負(fù)載。
  • 隨機(jī)法:通過(guò)系統(tǒng)的隨機(jī)算法,根據(jù)后端服務(wù)器的列表大小值來(lái)隨機(jī)選取其中的一臺(tái)服務(wù)器進(jìn)行訪問(wèn)。
  • 源地址哈希法:根據(jù)獲取客戶(hù)端的IP地址,通過(guò)哈希函數(shù)計(jì)算得到一個(gè)數(shù)值,用該數(shù)值對(duì)服務(wù)器列表的大小進(jìn)行取模運(yùn)算,得到的結(jié)果便是客服端要訪問(wèn)服務(wù)器的序號(hào)。采用源地址哈希法進(jìn)行負(fù)載均衡,同一IP地址的客戶(hù)端,當(dāng)后端服務(wù)器列表不變時(shí),它每次都會(huì)映射到同一臺(tái)后端服務(wù)器進(jìn)行訪問(wèn)。
  • 加權(quán)輪詢(xún)法:不同的后端服務(wù)器可能機(jī)器的配置和當(dāng)前系統(tǒng)的負(fù)載并不相同,因此它們的抗壓能力也不相同。給配置高、負(fù)載低的機(jī)器配置更高的權(quán)重,讓其處理更多的請(qǐng);而配置低、負(fù)載高的機(jī)器,給其分配較低的權(quán)重,降低其系統(tǒng)負(fù)載,加權(quán)輪詢(xún)能很好地處理這一問(wèn)題,并將請(qǐng)求順序且按照權(quán)重分配到后端。
  • 加權(quán)隨機(jī)法:與加權(quán)輪詢(xún)法一樣,加權(quán)隨機(jī)法也根據(jù)后端機(jī)器的配置,系統(tǒng)的負(fù)載分配不同的權(quán)重。不同的是,它是按照權(quán)重隨機(jī)請(qǐng)求后端服務(wù)器,而非順序。
  • 最小連接數(shù)法:由于后端服務(wù)器的配置不盡相同,對(duì)于請(qǐng)求的處理有快有慢,最小連接數(shù)法根據(jù)后端服務(wù)器當(dāng)前的連接情況,動(dòng)態(tài)地選取其中當(dāng)前積壓連接數(shù)最少的一臺(tái)服務(wù)器來(lái)處理當(dāng)前的請(qǐng)求,盡可能地提高后端服務(wù)的利用效率,將負(fù)責(zé)合理地分流到每一臺(tái)服務(wù)器。

2.如何用PHP實(shí)現(xiàn)加權(quán)輪詢(xún)?

實(shí)現(xiàn)思路:

通過(guò)傳入不同的用戶(hù)id,然后給他們分配不同的主機(jī)。

首先,需要一個(gè)接收用戶(hù)id的數(shù)組。

其次,需要一個(gè)存主機(jī)的數(shù)組,這些主機(jī)有不同的權(quán)重。這里的權(quán)重可以這么考慮:

假設(shè)有abc三臺(tái)主機(jī),權(quán)重分別為3,1,1,那么a的占比為0.6,b和c的占比各為0.2。

直接遍歷主機(jī)的數(shù)組,假如用戶(hù)來(lái)了100個(gè)人,到a的時(shí)候,a的占比是0.6,就從用戶(hù)數(shù)組里隨機(jī)取60個(gè)人分給a;輪到b時(shí),b的占比是0.2,就從用戶(hù)數(shù)組里隨機(jī)取20人;同理,c20人,這樣就完成了100個(gè)請(qǐng)求的轉(zhuǎn)發(fā)。

可是真實(shí)場(chǎng)景不是固定一批用戶(hù),而是持續(xù)不斷的用戶(hù)請(qǐng)求,由于轉(zhuǎn)發(fā)非常快,當(dāng)來(lái)的新用戶(hù)非常少時(shí),每次從用戶(hù)隊(duì)列中取完、轉(zhuǎn)發(fā)后立馬去用戶(hù)隊(duì)列中取,很有可能每次只取2條,造成請(qǐng)求全部給了a,b和c一直沒(méi)有的情況。這時(shí)候可以考慮按照不同策略從用戶(hù)隊(duì)列中取數(shù)據(jù)。假設(shè)以前5ms就處理完一次轉(zhuǎn)發(fā),則現(xiàn)在定義兩種策略,如果用戶(hù)隊(duì)列中有100個(gè)用戶(hù)時(shí),就取出來(lái),按著主機(jī)占比進(jìn)行轉(zhuǎn)發(fā),如果用戶(hù)隊(duì)列中不足100人,但是當(dāng)前時(shí)間和上一次取值時(shí)間相差10ms,就取出來(lái)進(jìn)行轉(zhuǎn)發(fā),這樣就可以累積5ms,而這5ms里隊(duì)列中又會(huì)多一些用戶(hù)請(qǐng)求,這樣就不會(huì)把所有請(qǐng)求都分給一臺(tái)機(jī)器了。

代碼:

?php
// php實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)(WRR)
class WRR {
  // 每次取100人
  const num = 100;
  // 上次取值時(shí)間,秒級(jí)時(shí)間戳
  public $last_time;
  // 權(quán)重 machine=>weight
  public $machines = array(
    'a' => 3, // 0.6
    'b' => 1, // 0.2
    'c' => 1 // 0.2
  );
  // 占比
  public $proportion = array();
  // 用戶(hù)隊(duì)列
  public static $user_ids = array();
  public function __construct() {
    // 各機(jī)器的占比
    $total = 0;
    foreach ($this->machines as $machine => $weight) {
      $total += $weight;
    }
    $this->proportion['a'] = $this->machines['a'] / $total;
    $this->proportion['b'] = $this->machines['b'] / $total;
    $this->proportion['c'] = $this->machines['c'] / $total;
  }
  public function getUsers() {
    // 用戶(hù)人數(shù)
    $cnt = count(self::$user_ids);
    $a_num = 0;
    $b_num = 0;
    $c_num = 0;
    if ($cnt >= self::num) { // 隊(duì)列超過(guò)100人
      $a_num = round(self::num * $this->proportion['a']);
      $b_num = round(self::num * $this->proportion['b']);
      $c_num = $cnt - $a_num - $b_num;
    } else { // 隊(duì)列不足100人
      $last_time = $this->last_time; // 上次訪問(wèn)時(shí)間
      while (true) {
        $current_time = $this->getMillisecond();
        if (($current_time - $last_time) >= 10) { // 當(dāng)前時(shí)間和上一次取值時(shí)間超過(guò)10ms
          $a_num = round($cnt * $this->proportion['a']);
          $b_num = round($cnt * $this->proportion['b']);
          $c_num = $cnt - $a_num - $b_num;
          $this->last_time = self::getMillisecond();  // 更新訪問(wèn)時(shí)間
          break;
        }
      }
    }
    $a = array_splice(self::$user_ids, 0, $a_num);
    $b = array_splice(self::$user_ids, 0, $b_num);
    $c = array_splice(self::$user_ids, 0, $c_num);
    return array(
      'a' => $a,
      'b' => $b,
      'c' => $c
    );
  }
  // 獲取毫秒級(jí)時(shí)間戳
  public function getMillisecond() {
    list($t1, $t2) = explode(" ", microtime());
    return (float)sprintf('%.0f', (floatval($t1) + floatval($t2)) * 1000);
  }
}
// 測(cè)試
$wrr = new WRR();
for ($i = 0; $i  3; $i++) {// 模擬持續(xù)不斷的用戶(hù)請(qǐng)求
  $random = rand(10, 120);
  $user_ids = range(1, $random);
  WRR::$user_ids = $user_ids;
  $users = $wrr->getUsers();
  print_r($users);
}

真實(shí)的算法比這個(gè)復(fù)雜多了,它需要考慮一點(diǎn),就是來(lái)過(guò)的用戶(hù)要保持原來(lái)分配的機(jī)器,除非原來(lái)的機(jī)器掛了。這樣做的原因是緩存。很多基于內(nèi)存的緩存,都是基于用戶(hù)級(jí)別的,所以相同的用戶(hù)保持同一臺(tái)機(jī)器,有助于提升性能。

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • Nginx 安裝筆記(含PHP支持、虛擬主機(jī)、反向代理負(fù)載均衡)
  • PHP開(kāi)發(fā)負(fù)載均衡指南
  • PHP實(shí)現(xiàn)負(fù)載均衡下的session共用功能
  • PHP實(shí)現(xiàn)負(fù)載均衡session共享redis緩存操作示例
  • Thinkphp結(jié)合AJAX長(zhǎng)輪詢(xún)實(shí)現(xiàn)PC與APP推送詳解
  • PHP經(jīng)典算法集錦【經(jīng)典收藏】
  • php 分庫(kù)分表hash算法
  • php的hash算法介紹
  • PHP中對(duì)各種加密算法、Hash算法的速度測(cè)試對(duì)比代碼
  • PHP實(shí)現(xiàn)的一致性Hash算法詳解【分布式算法】

標(biāo)簽:白銀 廊坊 太原 衡陽(yáng) 綏化 崇左 辛集 鄂州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法分析》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),負(fù)載,均衡,的,加權(quán),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法分析》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于PHP實(shí)現(xiàn)負(fù)載均衡的加權(quán)輪詢(xún)方法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 女高中中生被C爽哭视频网站| 黄色app在线看| 国产美女视频免费看网站| 夜夜操狠狠操| 日本韩国推理片免费观看电影| 老婆孩子热炕头| 免费看电影未满十八周岁| 蜜汁tv| 日本体内she精汇编合集| 欧美乱码精品一区二区三区竹菊| 你的就是比我老公的大| 韩国60岁丰满妇女茸茸 | 摸大乳喷奶水www视频| 老太奶性bbw.bbw| 免费久久99精品国产自在观| 三上悠亚办公室| 广元市| 三级国产三级在线| 国产精品情侣呻吟对白视频 | 蜜桃AV鲁一鲁一鲁一鲁| 91精品成人国产乱的特点| 夜夜躁狠狠躁日日躁aab| 国产在线看片护士免费视频| 国产jzjzjz免费大全视频| 以女性视角写的高H爽文| 天门市| 亚洲国产人成中文幕一级二级| 女同学浮乱系列辣文小说| 午夜色综合| 看印度三级伦里电影| 被黑人灌醉强系列小说| 床戏吻胸摸腿有叫声| 龟甲情欲小说| 女生被男生操的视频| 暴力被迫japanesevideossex| 齐天大圣孙悟空2002张卫健版| 欧美精品免费观看| 激情高潮呻吟抽搐喷水| 三级特黄40分钟在线播放| 江湖淫雄| 16真实处破女|