精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

詳解Nginx負載均衡配置誤區

Linux愛好者 ? 來源:51cto ? 作者:mb5ff980f81f3d8 ? 2021-05-13 14:36 ? 次閱讀

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

先看官網文檔中的描述

3ea34db0-b3a2-11eb-bf61-12bb97331649.png

官網文檔中解釋max_fails是指在fail_timeout配置的時間內,服務器通信失敗的次數,默認為1,即在fail_timeout時間內,1次請求失敗即不再嘗試,將請求根據hash規則,轉發到下一個上游服務

fail_timeout有兩種含義:

當已經確認上游服務不可用時,是指與上游服務器通信失敗次數的時間

服務器不可用的時間段

默認是10s

文字不是很好理解,搭建個實驗環境,環境如下:

Nginx

PHP-FPM(x2)

nginx通過fast-cgi將php請求轉發到PHP-FPM,這里PHP-FPM服務即上游服務,設置upstream,負載PHP-FPM

3eb3feda-b3a2-11eb-bf61-12bb97331649.png

3ec5be9a-b3a2-11eb-bf61-12bb97331649.png

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

現在通過tailf分別監聽兩個PHP-FPM日志

3ed58e06-b3a2-11eb-bf61-12bb97331649.png

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

可以從上面的日志中看到,按照輪詢規則,下次請求應該落到PHP-FPM2上面,接著,關掉PHP-FPM1,繼續請求

3ee02596-b3a2-11eb-bf61-12bb97331649.png

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

3ef35aa8-b3a2-11eb-bf61-12bb97331649.png

可以看到,關掉PHP-FPM1后,發起的請求,本來第二次請求(1758)應該分發到PHP-FPM1的,然后從Nginx錯誤日志可以看到,連接PHP-FPM1失敗,這里只做了一次失敗嘗試,然后Nginx將請求轉發到PHP-FPM2處理了

接著將max_fails設置為2,繼續上面的請求

3efd6d7c-b3a2-11eb-bf61-12bb97331649.png

開啟PHP-FPM1,繼續請求,兩個負載輪詢轉發請求

3f0c7650-b3a2-11eb-bf61-12bb97331649.png

接著繼續關掉PHP-FPM1,連續發起多次請求,查看日志

3f1b1214-b3a2-11eb-bf61-12bb97331649.png

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

3f325b40-b3a2-11eb-bf61-12bb97331649.png

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

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

3f449d0a-b3a2-11eb-bf61-12bb97331649.png

繼續分發到PHP-FPM2,接著看Nginx錯誤日志

3f602872-b3a2-11eb-bf61-12bb97331649.png

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

這里有幾個誤區:

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

這個理解是錯誤的,Nginx只是記錄了失敗的請求到日志,并將這個請求又轉發到了可用的其他上游服務,知道所有上游都不可用時,才會返回錯誤狀態

max_fails是指連續請求失敗的次數

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

fail_timeout越短越好

當訪問量大的時候,fail_timeout設置太短,會導致不斷的嘗試與不可用上游的連接,耗費大量的tcp資源進行連接

fail_timeout越長越好

當訪問量大的時候,fail_timeout設置太長,會導致負載不均衡,有可能會擊穿某個上游后端,達不到負載的效果

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 服務器
    +關注

    關注

    12

    文章

    9024

    瀏覽量

    85186
  • PHP
    PHP
    +關注

    關注

    0

    文章

    452

    瀏覽量

    26650
  • 負載均衡
    +關注

    關注

    0

    文章

    106

    瀏覽量

    12360

原文標題:Nginx負載均衡配置誤區

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    多鏈路負載均衡設置在哪里?

    多鏈路負載均衡設置涉及交換機、路由器和(可選)負載均衡器的設置。首先規劃網絡拓撲和IP地址,備份設備配置。然后,在交換機上
    的頭像 發表于 11-13 10:19 ?84次閱讀

    nginx負載均衡配置介紹

    目錄 nginx負載均衡 nginx負載均衡介紹 反向代理與
    的頭像 發表于 11-10 13:39 ?187次閱讀
    <b class='flag-5'>nginx</b><b class='flag-5'>負載</b><b class='flag-5'>均衡</b><b class='flag-5'>配置</b>介紹

    華納云:什么是負載均衡?優化資源利用率的策略

    負載均衡是現代計算機網絡架構中不可或缺的一部分,它通過智能分配請求和任務,確保系統資源的高效利用。本文將探討負載均衡的概念、工作原理、優化資源利用率的策略及其在實際應用中的重要性。 1
    的頭像 發表于 10-28 16:07 ?119次閱讀

    天翼云彈性負載均衡介紹

    負載均衡(Load Balancing)是一種優化資源分配的技術,主要用于在網絡環境中分散工作負載,以提高系統的響應速度、吞吐量以及可靠性。在互聯網服務中,當單臺服務器無法處理大量并發請求時,就需要
    的頭像 發表于 10-25 16:20 ?393次閱讀
    天翼云彈性<b class='flag-5'>負載</b><b class='flag-5'>均衡</b>介紹

    IPVS負載均衡原理解析

    ipvs (IP Virtual Server) 實現了傳輸層負載均衡,也就是我們常說的4層LAN交換,作為 Linux 內核的一部分。ipvs運行在主機上,在真實服務器集群前充當負載均衡
    的頭像 發表于 10-24 17:34 ?169次閱讀

    零基礎也可以搞懂負載均衡怎么配置

    負載均衡怎么配置?在Linux中配置負載均衡器的步驟涉及多個環節,包括選擇
    的頭像 發表于 10-12 15:58 ?194次閱讀

    負載均衡服務由幾部分組成?分別是什么

    均衡服務通常由六部分組成,分別是客戶端、負載均衡器、后端服務器、負載均衡算法、監控和健康檢查及會話保持。這六者互相協同工作,實現了流量的有效
    的頭像 發表于 09-18 11:16 ?229次閱讀

    nginx重啟命令linux步驟是什么?

      1、驗證nginx配置文件是否正確   方法一:進入nginx安裝目錄sbin下,輸入命令./nginx -t   看到如下顯示nginx
    發表于 07-11 17:13

    nginx重啟命令linux步驟是什么?

      1、驗證nginx配置文件是否正確   方法一:進入nginx安裝目錄sbin下,輸入命令./nginx -t   看到如下顯示nginx
    發表于 07-10 16:40

    視頻網站服務器的四種負載均衡技術

    視頻網站通常會面臨大量的用戶訪問和視頻流量,為了提高性能和可用性,需要使用負載均衡技術。以下是四種常用的視頻網站服務器負載均衡技術: 1、基于DNS的
    的頭像 發表于 04-01 17:36 ?590次閱讀

    負載均衡器的誕生和工作機制

    今天我們來深度揭秘一下負載均衡器 LVS 的秘密,相信大家看了你管這破玩意兒叫負載均衡?這篇文章后,還是有不少疑問,比如 LVS 看起來只有類似路由器的轉發功能,為啥說它是四層(傳輸層
    的頭像 發表于 01-04 12:26 ?947次閱讀
    <b class='flag-5'>負載</b><b class='flag-5'>均衡</b>器的誕生和工作機制

    Nginx在Windows/docker中的使用

    nginx 是一個高性能的開源反向代理服務器和 web 服務器,一般用來搭建靜態資源服務器、負載均衡器、反向代理,本文將分享其在 Windows/docker 中的使用,使用 nssm 部署成服務的方案腳本,局域網中自定義域名解
    的頭像 發表于 01-03 10:20 ?1758次閱讀
    <b class='flag-5'>Nginx</b>在Windows/docker中的使用

    如何確定適合的負載均衡比例

    路由器的負載均衡是一種應用于網絡中的技術,它可以平衡網絡流量的分配,提高網絡的性能和穩定性。在配置路由器的負載均衡時,選擇合適的
    的頭像 發表于 12-15 10:36 ?1473次閱讀

    路由器負載均衡怎么配置

    路由器負載均衡是一種重要的網絡技術,它能夠將多個網絡連接的流量分配到多個路由器上,以提高網絡的性能和穩定性。本文將詳細介紹路由器負載均衡配置
    的頭像 發表于 12-13 11:17 ?3163次閱讀

    Nginx配置文件如何設置頭信息保留真實IP不丟失

    Nginx 配置中設置頭信息以保留客戶端的真實 IP 地址通常是在使用反向代理的場景中需要的。當 Nginx 作為反向代理時,客戶端的真實 IP 地址可能會在轉發請求時丟失,因為到達應用服務器
    的頭像 發表于 11-30 10:54 ?1889次閱讀