Nginx代理功能與負載均衡詳解

来源:http://www.cnblogs.com/knowledgesea/archive/2016/02/19/5199046.html
-Advertisement-
Play Games

序言 Nginx的代理功能與負載均衡功能是最常被用到的,關於nginx的基本語法常識與配置已在上篇文章中有說明,這篇就開門見山,先描述一些關於代理功能的配置,再說明負載均衡詳細。 Nginx代理服務的配置說明 1、上一篇中我們在http模塊中有下麵的配置,當代理遇到狀態碼為404時,我們把404頁面


序言

Nginx的代理功能與負載均衡功能是最常被用到的,關於nginx的基本語法常識與配置已在上篇文章中有說明,這篇就開門見山,先描述一些關於代理功能的配置,再說明負載均衡詳細。

Nginx代理服務的配置說明

1、上一篇中我們在http模塊中有下麵的配置,當代理遇到狀態碼為404時,我們把404頁面導向百度。

error_page 404 https://www.baidu.com; #錯誤頁

然而這個配置,細心的朋友可以發現他並沒有起作用。

如果我們想讓他起作用,我們必須配合著下麵的配置一起使用

proxy_intercept_errors on;    #如果被代理伺服器返回的狀態碼為400或者大於400,設置的error_page配置起作用。預設為off。

2、如果我們的代理只允許接受get,post請求方法的一種

proxy_method get;    #支持客戶端的請求方法。post/get

3、設置支持的http協議版本

proxy_http_version 1.0 ; #Nginx伺服器提供代理服務的http協議版本1.01.1,預設設置為1.0版本

4、如果你的nginx伺服器給2台web伺服器做代理,負載均衡演算法採用輪詢,那麼當你的一臺機器web程式iis關閉,也就是說web不能訪問,那麼nginx伺服器分發請求還是會給這台不能訪問的web伺服器,如果這裡的響應連接時間過長,就會導致客戶端的頁面一直在等待響應,對用戶來說體驗就打打折扣,這裡我們怎麼避免這樣的情況發生呢。這裡我配張圖來說明下問題。

 

如果負載均衡中其中web2發生這樣的情況,nginx首先會去web1請求,但是nginx在配置不當的情況下會繼續分發請求道web2,然後等待web2響應,直到我們的響應時間超時,才會把請求重新分發給web1,這裡的響應時間如果過長,用戶等待的時間就會越長。

下麵的配置是解決方案之一。

proxy_connect_timeout 1;   #nginx伺服器與被代理的伺服器建立連接的超時時間,預設60秒
proxy_read_timeout 1; #nginx伺服器想被代理伺服器組發出read請求後,等待響應的超時間,預設為60秒。
proxy_send_timeout 1; #nginx伺服器想被代理伺服器組發出write請求後,等待響應的超時間,預設為60秒。
proxy_ignore_client_abort on;  #客戶端斷網時,nginx伺服器是否終端對被代理伺服器的請求。預設為off。

5、如果使用upstream指令配置啦一組伺服器作為被代理伺服器,伺服器中的訪問演算法遵循配置的負載均衡規則,同時可以使用該指令配置在發生哪些異常情況時,將請求順次交由下一組伺服器處理。

proxy_next_upstream timeout;  #反向代理upstream中設置的伺服器組,出現故障時,被代理伺服器返回的狀態值。error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off

error:建立連接或向被代理的伺服器發送請求或讀取響應信息時伺服器發生錯誤。

timeout:建立連接,想被代理伺服器發送請求或讀取響應信息時伺服器發生超時。

invalid_header:被代理伺服器返回的響應頭異常。

off:無法將請求分發給被代理的伺服器。

http_400,....:被代理伺服器返回的狀態碼為400,500,502,等。

6、如果你想通過http獲取客戶的真是ip而不是獲取代理伺服器的ip地址,那麼要做如下的設置。

proxy_set_header Host $host; #只要用戶在瀏覽器中訪問的功能變數名稱綁定了 VIP VIP 下麵有RS;則就用$host ;host是訪問URL中的功能變數名稱和埠  www.taobao.com:80
proxy_set_header X-Real-IP $remote_addr;  #把源IP 【$remote_addr,建立HTTP連接header裡面的信息】賦值給X-Real-IP;這樣在代碼中 $X-Real-IP來獲取 源IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;#在nginx 作為代理伺服器時,設置的IP列表,會把經過的機器ip,代理機器ip都記錄下來,用 【,】隔開;代碼中用 echo $x-forwarded-for |awk -F, '{print $1}' 來作為源IP

關於X-Forwarded-For與X-Real-IP的一些相關文章我推薦一位博友的:HTTP 請求頭中的 X-Forwarded-For ,這位博友對http協議有一系列的文章闡述,推薦大家去關註下。

7、下麵是我的一個關於代理配置的配置文件部分,僅供參考。

    include       mime.types;   #文件擴展名與文件類型映射表
    default_type  application/octet-stream; #預設文件類型,預設為text/plain
    #access_log off; #取消服務日誌    
    log_format myFormat ' $remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定義格式
    access_log log/access.log myFormat;  #combined為日誌格式的預設值
    sendfile on;   #允許sendfile方式傳輸文件,預設為off,可以在http塊,server塊,location塊。
    sendfile_max_chunk 100k;  #每個進程每次調用傳輸數量不能大於設定的值,預設為0,即不設上限。
    keepalive_timeout 65;  #連接超時時間,預設為75s,可以在http,server,location塊。
    proxy_connect_timeout 1;   #nginx伺服器與被代理的伺服器建立連接的超時時間,預設60秒
    proxy_read_timeout 1; #nginx伺服器想被代理伺服器組發出read請求後,等待響應的超時間,預設為60秒。
    proxy_send_timeout 1; #nginx伺服器想被代理伺服器組發出write請求後,等待響應的超時間,預設為60秒。
    proxy_http_version 1.0 ; #Nginx伺服器提供代理服務的http協議版本1.01.1,預設設置為1.0版本。
    #proxy_method get;    #支持客戶端的請求方法。post/get;
    proxy_ignore_client_abort on;  #客戶端斷網時,nginx伺服器是否終端對被代理伺服器的請求。預設為off。
    proxy_ignore_headers "Expires" "Set-Cookie";  #Nginx伺服器不處理設置的http相應投中的頭域,這裡空格隔開可以設置多個。
    proxy_intercept_errors on;    #如果被代理伺服器返回的狀態碼為400或者大於400,設置的error_page配置起作用。預設為off。
    proxy_headers_hash_max_size 1024; #存放http報文頭的哈希表容量上限,預設為512個字元。
    proxy_headers_hash_bucket_size 128; #nginx伺服器申請存放http報文頭的哈希表容量大小。預設為64個字元。
    proxy_next_upstream timeout;  #反向代理upstream中設置的伺服器組,出現故障時,被代理伺服器返回的狀態值。error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off
    #proxy_ssl_session_reuse on; 預設為on,如果我們在錯誤日誌中發現“SSL3_GET_FINSHED:digest check failed”的情況時,可以將該指令設置為off。

Nginx負載均衡詳解

上一篇中我說啦nginx有哪些中負載均衡演算法。這一結我就給如果操作配置的給大家做詳細說明下。

首先給大家說下upstream這個配置的,這個配置是寫一組被代理的伺服器地址,然後配置負載均衡的演算法。這裡的被代理伺服器地址有2中寫法。

 

upstream mysvr { 
      server 192.168.10.121:3333;
      server 192.168.10.122:3333;
    }
 server {
        ....
        location  ~*^.+$ {         
           proxy_pass  http://mysvr;  #請求轉向mysvr 定義的伺服器列表         
        } 

 

upstream mysvr { 
      server  http://192.168.10.121:3333;
      server  http://192.168.10.122:3333;
    }
 server {
        ....
        location  ~*^.+$ {         
           proxy_pass  mysvr;  #請求轉向mysvr 定義的伺服器列表         
        } 

然後,就來點實戰的東西。

1、熱備:如果你有2台伺服器,當一臺伺服器發生事故時,才啟用第二台伺服器給提供服務。伺服器處理請求的順序:AAAAAA突然A掛啦,BBBBBBBBBBBBBB.....

upstream mysvr { 
      server 127.0.0.1:7878; 
      server 192.168.10.121:3333 backup;  #熱備     
    }

2、輪詢:nginx預設就是輪詢其權重都預設為1,伺服器處理請求的順序:ABABABABAB....

upstream mysvr { 
      server 127.0.0.1:7878;
      server 192.168.10.121:3333;       
    }

3、加權輪詢:跟據配置的權重的大小而分發給不同伺服器不同數量的請求。如果不設置,則預設為1。下麵伺服器的請求順序為:ABBABBABBABBABB....

 upstream mysvr { 
      server 127.0.0.1:7878 weight=1;
      server 192.168.10.121:3333 weight=2;
}

4、ip_hash:nginx會讓相同的客戶端ip請求相同的伺服器。

upstream mysvr { 
      server 127.0.0.1:7878; 
      server 192.168.10.121:3333;
      ip_hash;
    }

5、如果你對上面4種均衡演算法不是很理解,那麼麻煩您去看下我上一篇配的圖片,可能會更加容易理解點。

到這裡你是不是感覺nginx的負載均衡配置特別簡單與強大,那麼還沒完,咱們繼續哈,這裡扯下蛋。

關於nginx負載均衡配置的幾個狀態參數講解。

  • down,表示當前的server暫時不參與負載均衡。

  • backup,預留的備份機器。當其他所有的非backup機器出現故障或者忙的時候,才會請求backup機器,因此這台機器的壓力最輕。

  • max_fails,允許請求失敗的次數,預設為1。當超過最大次數時,返回proxy_next_upstream 模塊定義的錯誤。

  • fail_timeout,在經歷了max_fails次失敗後,暫停服務的時間。max_fails可以和fail_timeout一起使用。

 upstream mysvr { 
      server 127.0.0.1:7878 weight=2 max_fails=2 fail_timeout=2;
      server 192.168.10.121:3333 weight=1 max_fails=2 fail_timeout=1;    
    }

到這裡應該可以說nginx的內置負載均衡演算法已經沒有貨啦。如果你像跟多更深入的瞭解nginx的負載均衡演算法,nginx官方提供一些插件大家可以瞭解下。

總結

如果你在開發過程中使用啦這些技術,或者你要使用遇到啦什麼問題,歡迎加入左上角的群,我們一起討論學習,本篇未完待續。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 引言--面向介面所處的設計模式中的位置。 其實,我認為Java/C#比C++高級的其中一個原因是,它對面向介面編程的支持。不要誤解,並不是說C++不支持面向介面編程,而是說C++的語法中沒有這種天然的機制。 面向對象之於面向過程,面向介面之於面向實現。但基本上,面向介面和麵向實現都基於面向對象的模式
  • Atitit.pdf 預覽 轉換html attilax總結 1. Swf flash還是html1 2. pdf2htmlEX1 3. iText 5.5.0 發佈,Java 的 PDF 操作類庫1 4. PdfBox1 5. other2 5.1. ICEpdf2 5.2. xpdf用過2 5.
  • 定義 適配器模式(Adapter):將一個類的介面轉換成客戶希望的另外一個介面 那通俗點來說,啥是適配器呢,大家都知道港版的iphone的充電器,是不能直接在內地使用的,需要一個轉換器才能使用,那麼這個 轉換器就是所謂的適配器 . 那麼適配器能夠給我們帶來什麼好處呢? 使用港版iPhone的同學都知
  • 裝飾模式(Decorator) 裝飾模式又名包裝(Wrapper)模式。 裝飾模式以對客戶端透明的方式擴展對象的功能,是繼承關係的一個替代方案。 裝飾模式通過創建一個包裝對象,也就是裝飾,來包裹真實的對象。 裝飾模式以對客戶端透明的方式動態地給一個對象附加上更多的責任。換言之,客戶端並不會覺得對象在
  • 1、簡介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel ,從而方便我們以優雅的、富有表現力的代碼實現Excel/CSV文件的導入和 導出 。 該項目的GitHub地址是: https://github.com/Maatwebsite/La
  • 什麼是設計模式 現在聊起來java設計,那就必然要聊聊設計模式,幾年前我剛入行的時候,總是聽人說起設計模式,在當時的我看來,那是多麼高大上的東西啊,以至於有種遙不可及的感覺,如今自己做java也好幾個年頭了,今天來談談如今我眼中的設計模式 說白了,設計模式就是前輩高人總結出來的一套編寫好代碼的方法,
  • 博主第一次開發商城類的項目,目前商城已上線,這裡就不打廣告了。商城的架構主要為yii2+backbone,還有一些其他blablablabla......的插件。 商城有PC端和微信端,先上線的PC端後上線微信端。 第一版的開發模式是,前端同學設計好界面原型,切好圖,做完靜態頁面交給後端人員。後端人
  • SRP單一職責原則 就一個類而言,應該僅有一個引起它變化的原因。 OCP開放封閉原則 軟體實體(類、模塊、函數等)應該是可以擴展的,但是不可修改。 LSP Liskov替換原則 子類型必須能夠替換掉它們的基類型 DIP 依賴倒置原則 抽象不應該依賴於細節。細節應該依賴於抽象。 ISP 介面隔離原則
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...