日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
這些 Nginx 負載均衡配置誤區(qū),運維請注意

之前有很多朋友問關(guān)于 Nginx 的 upstream 模塊中 max_fails 及 fail_timeout,這兩個指令,分別是配置關(guān)于負載均衡過程中,對于上游(后端)服務(wù)器的失敗嘗試次數(shù)和不可用時間,很多人不是很理解這兩個參數(shù)到底怎么用及具體的含義。

為企業(yè)提供網(wǎng)站設(shè)計制作、成都做網(wǎng)站、網(wǎng)站優(yōu)化、成都全網(wǎng)營銷、競價托管、品牌運營等營銷獲客服務(wù)。成都創(chuàng)新互聯(lián)公司擁有網(wǎng)絡(luò)營銷運營團隊,以豐富的互聯(lián)網(wǎng)營銷經(jīng)驗助力企業(yè)精準(zhǔn)獲客,真正落地解決中小企業(yè)營銷獲客難題,做到“讓獲客更簡單”。自創(chuàng)立至今,成功用技術(shù)實力解決了企業(yè)“網(wǎng)站建設(shè)、網(wǎng)絡(luò)品牌塑造、網(wǎng)絡(luò)營銷”三大難題,同時降低了營銷成本,提高了有效客戶轉(zhuǎn)化率,獲得了眾多企業(yè)客戶的高度認可!

先看官網(wǎng)文檔中的描述

官網(wǎng)文檔中解釋 max_fails 是指在 fail_timeout 配置的時間內(nèi),服務(wù)器通信失敗的次數(shù),默認為1,即在 fail_timeout 時間內(nèi),1次請求失敗即不再嘗試,將請求根據(jù) hash 規(guī)則,轉(zhuǎn)發(fā)到下一個上游服務(wù)

fail_timeout 有兩種含義:

  • 當(dāng)已經(jīng)確認上游服務(wù)不可用時,是指與上游服務(wù)器通信失敗次數(shù)的時間
  • 服務(wù)器不可用的時間段

默認是10s

文字不是很好理解,搭建個實驗環(huán)境,環(huán)境如下:

  • Nginx
  • PHP-FPM(x2)

nginx 通過 fast-cgi 將 php 請求轉(zhuǎn)發(fā)到 PHP-FPM,這里 PHP-FPM 服務(wù)即上游服務(wù),設(shè)置 upstream,負載 PHP-FPM

upstream 按照默認配置,即 max_fails=1,fail_timeout=10

現(xiàn)在通過 tailf 分別監(jiān)聽兩個 PHP-FPM 日志

請求4次,因為是默認輪詢的,所以可以看時間,輪詢將請求分發(fā)到兩個PHP-FPM上游

可以從上面的日志中看到,按照輪詢規(guī)則,下次請求應(yīng)該落到 PHP-FPM2 上面,接著,關(guān)掉 PHP-FPM1,繼續(xù)請求

可以看到,PHP-FPM1肯定是不響應(yīng)了,PHP-FPM2正常響應(yīng),接著看下Nginx日志

可以看到,關(guān)掉 PHP-FPM1 后,發(fā)起的請求,本來第二次請求(17:49:58)應(yīng)該分發(fā)到 PHP-FPM1 的,然后從 Nginx 錯誤日志可以看到,連接 PHP-FPM1 失敗,這里只做了一次失敗嘗試,然后 Nginx 將請求轉(zhuǎn)發(fā)到 PHP-FPM2 處理了。

接著將 max_fails 設(shè)置為2,繼續(xù)上面的請求

開啟 PHP-FPM1,繼續(xù)請求,兩個負載輪詢轉(zhuǎn)發(fā)請求

接著繼續(xù)關(guān)掉 PHP-FPM1,連續(xù)發(fā)起多次請求,查看日志

所有請求都在 PHP-FPM2上,看 Nginx 錯誤日志

兩次輪詢到PHP-FPM1的時候,失敗,之后不會再將請求分發(fā)到 PHP-FPM1 上游服務(wù)

接著,不開啟 PHP-FPM1,繼續(xù)發(fā)起多次請求,由于默認的 fail_timeout=10,所以在上面的失敗檢測 10s 之后再次發(fā)起請求,查看日志

繼續(xù)分發(fā)到 PHP-FPM2,接著看 Nginx 錯誤日志

可以看到,過了 fail_timeout 的時間后,Ngxin 會再次將請求發(fā)往 FPM-PHP1 進行嘗試,嘗試2次失敗后,在 fail_timeout 時間內(nèi),不會再將請求分發(fā),

這里有幾個誤區(qū):

  • Nginx 記錄了連接上游失敗,這個請求就返回錯誤請求,或這個請求丟失沒處理

這個理解是錯誤的,Nginx 只是記錄了失敗的請求到日志,并將這個請求又轉(zhuǎn)發(fā)到了可用的其他上游服務(wù),知道所有上游都不可用時,才會返回錯誤狀態(tài)

  • max_fails 是指連續(xù)請求失敗的次數(shù)

max_fails 是在 fail_timeout 指定的時間內(nèi)的失敗次數(shù),請求還是按照配置的負載均衡算法來走,并不是第一次請求失敗之后,繼續(xù)將這個請求在嘗試一次,達到失敗次數(shù)之后,標(biāo)記為不可用

  • fail_timeout 越短越好

當(dāng)訪問量大的時候,fail_timeout 設(shè)置太短,會導(dǎo)致不斷的嘗試與不可用上游的連接,耗費大量的 tcp 資源進行連接

  • fail_timeout 越長越好

當(dāng)訪問量大的時候,fail_timeout設(shè)置太長,會導(dǎo)致負載不均衡,有可能會擊穿某個上游后端,達不到負載的效果。


當(dāng)前文章:這些 Nginx 負載均衡配置誤區(qū),運維請注意
文章出自:http://www.5511xx.com/article/cdhohoj.html