主頁 > 軟體設計 > nginx 負載均衡配置

nginx 負載均衡配置

2021-11-05 07:50:26 軟體設計

組態檔的位置:/usr/local/nginx/conf/nginx.conf

user
#user  www www;
nginx 運行的用戶和用戶組,默認為 nobody

pid
pid  logs/nginx.pid;

行程檔案配置,默認為 logs/nginx.pid

error_log
error_log  logs/error.log  warn;
錯誤日志配置,

日志級別可選:debug < info < notice < warn < error < crit

日志級別越高,記錄的日志資訊越少

worker_processes
worker_processes  1;
nginx 對外提供 web 服務的 worder 行程數,通常設定和 cpu 核數的數量相等


worker_rlimit_nofile
worker_rlimit_nofile 1024;
一個 worker 行程能打開的檔案的最大數目,

理論值應該是系統最多能打開的檔案數(在 linux 中執行 ulimit -n 可得到值)與 worker 行程數相

除得到的值,但是 nginx 分配請求并不均勻,建議與 ulimit -n 的值保持一致

events
events {
    worker_connections  1024;
    use epoll;
}
worker_connections
worker_connections  1024;
設定單個 worker 行程最大連接數

use
use epoll;
設定復用客戶端執行緒的輪詢方法

use  [  kqueue  |  rtsig  |  epoll  |  select  |  poll  ]

epoll 是 linux 2.6 以上版本內核中的高性能網路 I / O 模型

如果不設定,nginx 會選擇一個最適合你作業系統的模型

http
http {
}
http 服務器配置

include
include  mime.types;
設定 MIME 型別(資源的媒體型別),通過 http 協議由 web 服務器回傳給客戶端瀏覽器,瀏覽器會自動使用指定應用程式來打開資源檔案

mime.types 檔案位于 /usr/local/nginx/conf/mime.types

default_type
default_type  application/octet-stream;
默認的資源檔案的媒體型別,application/octet-stream 為任意的二進制資料流傳輸

log_format
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                  '$status $body_bytes_sent "$http_referer" '
                  '"$http_user_agent" "$http_x_forwarded_for"';

日志格式,"log_format  main"  這里的 main 是日志格式的名稱,通過不同名稱來定義多種日志格式


在這里插入圖片描述

access_log
access_log  logs/access.log  main;
配置訪問日志,可以指定使用的日志格式,如這里的 main

charset
charset  UTF-8;
使用的字符集編碼

sendfile
sendfile  on;
通過呼叫 sendfile 函式(sendfile 是一個系統呼叫,在內核空間中完成),可以高效的發送靜態檔案

tcp_nopush
tcp_nopush  on;
一次性發送資料包,與 tcp_nodelay 配置項互斥,與 sendfile 配合作業

tcp_nodelay
#tcp_nodelay  on;0.2 秒后立即發送一個資料包,可以有效的防止網路阻塞,當需要及時發送資料時,應該開啟它

keepalive_timeout
keepalive_timeout  60;
配置長連接的超時時間,服務器將在這個超時時間過后關閉鏈接

client_header_timeout
client_header_timeout  120;
等待客戶端發送一個請求頭的超時時間,超時 Nginx 回傳一個請求超時的狀態碼(408,Request Timeout)

client_body_timeout
client_body_timeout  120;
等待客戶端發送一個請求體的超時時間,超時 Nginx 回傳一個請求超時的狀態碼(408,Request Timeout)

send_timeout
send_timeout 120;
客戶端讀取資料的超時時間,超時 Nginx 就會關閉該連接

client_header_buffer_size
client_header_buffer_size  16k;
快取客戶端請求頭的大小

large_client_header_buffers
large_client_header_buffers  4 32k;
快取客戶端請求頭的最大大小,此處為 432K 的大小

gzip
gzip  on;
采用 gzip 壓縮的形式發送資料,可以減少發送的資料量

gzip_min_length
gzip_min_length  1k;
大于該值的內容才壓縮,0 表示所有的內容都壓縮

gzip_buffers
gzip_buffers  4 16k;
快取 gzip 壓縮資料的空間大小,此處為 416K 的大小

gzip_types
gzip_types  text/plain text/css application/x-javascript application/xml;
只有匹配配置的 MIME 型別的檔案內容才會被壓縮

nginx 默認會對 text/html 型別進行壓縮,此處無需再配,若配置 text/html,nginx 會發出警告:

nginx: [ warn ] duplicate MIME type "text/html"

server_names_hash_bucket_size
server_names_hash_bucket_size 128;
服務器名稱的 hash 表大小,如果太小,Nginx 無法啟動

server
server {
}
虛擬主機配置

listen
listen  80;
監聽埠

server_name
server_name  fanlychie.com www.fanlychie.com;
域名,可以配置多個,以空格分開

access_log
access_log  logs/fanlychie.access.log  main;
虛擬主機訪問日志,

root
root  www.fanlychie.com;
網站根目錄,用于存放網站靜態資源檔案,若為相對路徑,則是相對于 nginx 安裝的目錄,如此處的物理路徑為 /usr/local/nginx/www.fanlychie.com

location
location / {
}

在這里插入圖片描述

多個 location 匹配 url 地址的優先級:

"=" 被匹配,停止搜索其他匹配

"^~" 被匹配,停止搜索其他匹配

"~""~*" 按組態檔中出現的先后順序,一旦匹配,停止搜索其他匹配

若以上都沒有匹配到,則交給 "/" 處理請求

expires
location ~ \.(js|css)$ {
    expires  1d;
}
js 和 css 檔案由 nginx 直接提供,快取一天

如客戶端訪問 http://www.fanlychie.com/styles/main.css

由于上面已經配置 root  www.fanlychie.com,nginx 會將

/usr/local/nginx/www.fanlychie.com/styles/main.css 檔案直接回傳給客戶端

location ~ \.(gif|jpg|jpeg|png|ico)$ {
    expires  7d;
}
同上面,圖片檔案快取 7 天

deny
location ~* \.jsp {
    deny  all;
}
禁止直接訪問 *.jsp 檔案(回傳 403 狀態碼給客戶端)

proxy_pass
location = / {
    proxy_set_header        Host             $host;
    proxy_set_header        X-Real-IP        $remote_addr;
    proxy_set_header        X-Forwarded-For  $proxy_add_x_forwarded_for;
    proxy_pass  http://www.fanlychie.com/index;
}
proxy_pass 配置反向代理

即通過域名訪問網站首頁,nginx 將請求轉發給真實的運用服務器處理,即

http://www.fanlychie.com/index (www.fanlychie.com 是上面配置的 server_name 的名稱)

proxy_set_header

在這里插入圖片描述

location / {
    proxy_pass  http://www.fanlychie.com;
    proxy_redirect          off;
    proxy_set_header        Host             $host;
    proxy_set_header        X-Real-IP        $remote_addr;
    proxy_set_header        X-Forwarded-For  $proxy_add_x_forwarded_for;
    client_max_body_size    10m;
    client_body_buffer_size 128k;
    proxy_connect_timeout   90;
    proxy_send_timeout      90;
    proxy_read_timeout      90;
    proxy_buffers           32 4k;
}

proxy_redirect
proxy_redirect 與 proxy_pass 用法類似,proxy_pass 是轉發請求,客戶端 url 地址不變;

proxy_redirect 是請求重定向,客戶端 url 地址發生變化,

client_max_body_size
允許客戶端請求的最大單檔案位元組數

client_body_buffer_size
代理緩沖用戶端請求的緩沖區最大位元組數

proxy_connect_timeout
代理連接超時時間(nginx 跟后端服務器連接超時時間)

proxy_send_timeout
代理發送超時時間(后端服務器資料回傳時間)

proxy_read_timeout
代理接收超時時間(連接成功后,后端服務器回應時間)

proxy_buffers
代理緩沖區的大小

error_page

location = /403.html {
    root  html;
}
location = /404.html {
    root  html;
}
location = /50x.html {
    root  html;
}
error_page  403              /403.html;
error_page  404              /404.html;
error_page  500 502 503 504  /50x.html;

錯誤頁面配置,

upstream

upstream www.fanlychie.com {
    server 192.168.1.102:8080;
    server 192.168.1.103:8080;
}

負載均衡配置

upstream www.fanlychie.com,此處的 www.fanlychie.com 是上面 server 模塊配置的

server_name,server 指定真實的運用服務主機地址,可以配置多個,

nginx 默認采用輪詢的策略,將請求平均的分配到各個運用服務主機中,當其中一臺服務主機宕機

后,會自動的被剔除,另外一臺服務主機仍然能正常提供服務,

weight

upstream www.fanlychie.com {
    server 192.168.1.102:8080 weight=1;
    server 192.168.1.103:8080 weight=2;
};

在輪詢的基礎上加上權重,數值越大,表示權值越大,nginx 分發的請求越多

用于運用服務器性能不均的情況,當其中一臺服務主機宕機后,會自動的被剔除,另外一臺服務主

機仍然能正常提供服務

ip_hash

upstream www.fanlychie.com {
    ip_hash;
    
    server 192.168.1.102:8080;
    server 192.168.1.103:8080;
}

每個請求按訪問 ip 的 hash 結果分配服務主機

當新的請求到達時,先將用戶 ip 通過哈希演算法求值,在隨后的請求客戶端 ip 的哈希值只要相同,

就會被分配至同一個后端服務器,這種調度可以解決 session 共享的問題,但有時會導致分配不均

即無法保證負載均衡

#user  nobody;
pid  logs/nginx.pid;
worker_processes  1;
worker_rlimit_nofile 1024;
error_log  logs/error.log  warn;
events {
    worker_connections  1024;
    use epoll;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    #access_log  logs/access.log  main;
    charset UTF-8;
    sendfile       on;
    tcp_nopush     on;
    #tcp_nodelay   on;
    keepalive_timeout  60;
    client_header_timeout  120;
    client_body_timeout    120;
    send_timeout           120;
    client_header_buffer_size    16k;
    large_client_header_buffers  4 32k;
    gzip  on;
    gzip_min_length  1k;
    gzip_buffers     4 16k;
    gzip_types       text/plain text/css application/x-javascript application/xml;
    server_names_hash_bucket_size 128;
    upstream www.fanlychie.com {
        server 192.168.1.102:8080;
        server 192.168.1.103:8080;
    }
    server {
        listen       80;
        server_name  fanlychie.com www.fanlychie.com;
        access_log   logs/fanlychie.access.log  main;
        root         www.fanlychie.com;
        location = / {
            proxy_set_header        Host            $host;
            proxy_set_header        X-Real-IP       $remote_addr;
            proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass  http://www.fanlychie.com/index;
        }
        location ~ \.(js|css)$ {
            expires  1d;
        }
        location ~ \.(gif|jpg|jpeg|png|ico)$ {
            expires  7d;
        }
        location ~* \.jsp {
            deny  all;
        }
        location / {
             proxy_pass  http://www.fanlychie.com;
             proxy_redirect          off;
             proxy_set_header        Host            $host;
             proxy_set_header        X-Real-IP       $remote_addr;
             proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
             client_max_body_size    10m;
             client_body_buffer_size 128k;
             proxy_connect_timeout   90;
             proxy_send_timeout      90;
             proxy_read_timeout      90;
             proxy_buffers           32 4k;
        }
        location = /403.html {
            root  html;
        }
        location = /404.html {
            root  html;
        }
        location = /50x.html {
            root  html;
        }
        error_page  404              /404.html;
        error_page  403              /403.html;
        error_page  500 502 503 504  /50x.html;
    }
}

附全域變數表

變數描述
$args請求的引數
$content_length請求頭中的 Content-length 域的值
$content_type請求頭中的 Content-Type 域的值
$host請求主機域的值,否則為服務器名稱
$http_user_agent客戶端 agent 資訊
$http_cookie客戶端 cookie 資訊
$request_method客戶端請求的動作,通常為 GET 或 POST
$remote_addr客戶端的 IP 地址
$remote_port客戶端的埠
$remote_user已經經過 Auth Basic Module 驗證的用戶名
$request_filename當前請求的檔案路徑
$query_string與 $args 同
$scheme HTTP方法(如 http,https)
$server_protocol請求使用的協議,通常是 HTTP/1.0 或 HTTP/1.1
$server_addr服務器地址,在完成一次系統呼叫后可以確定這個值
$server_name服務器名稱
$server_port請求到達服務器的埠號
$request_uri包含請求引數的原始 URI,不包含主機名,如:"/foo/bar.php?arg=baz"
$uri不帶請求引數的當前 URI,$uri 不包含主機名,如 “/foo/bar.html”
$document_uri與 $uri 同

附運算式串列

運算式運算式描述
-f!-f判斷檔案是否存在
-d!-d判斷目錄是否存在
-e!-e判斷檔案或目錄是否存在
-x!-x判斷檔案是否可執行

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/348336.html

標籤:其他

上一篇:計算機考研408每日一題 day116

下一篇:我的畢設實戰指南

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more