国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

nginx(三):反向代理篇

cloud / 2205人閱讀

摘要:反向代理模塊何為反向代理接收客戶端請(qǐng)求,并把請(qǐng)求交給后端服務(wù)器處理,后端服務(wù)器處理完成后,響應(yīng)通過反向代理服務(wù)器返回給客戶端。作為反向代理服務(wù)器經(jīng)常要配置一組服務(wù)器,以實(shí)現(xiàn)負(fù)載均衡。

1、nginx反向代理模塊

何為反向代理?接收客戶端請(qǐng)求,并把請(qǐng)求交給后端服務(wù)器處理,后端服務(wù)器處理完成后,響應(yīng)通過反向代理服務(wù)器返回給客戶端。反向代理可實(shí)現(xiàn)局域網(wǎng)中的服務(wù)器可被公網(wǎng)中的客戶端訪問,也可實(shí)現(xiàn)多臺(tái)服務(wù)器間做負(fù)載均衡。
模塊:ngx_http_proxy_module

1.1 proxy_pass

作用域Context: location, if in location, limit_except

syntax:proxy_pass URL;

核心指令,該指令設(shè)置被代理服務(wù)器地址,URL是主機(jī)名稱,IP,IP加端口等形式,并且?guī)в袀鬏攨f(xié)議http://或https://
需要注意的時(shí),URL中含有與不含有uri,nginx對(duì)其處理方式是不同的
配置示例:
情況一:URL不含uri

server {
                    ...
                    server_name www.cutemsyu.com;
                    location /uri/ {
                        proxy_pass http://192.168.100.1:8080;
                    }
                    ...
                }
nginx對(duì)于此種情況的處理方式是,將location中的uri傳遞給后端服務(wù)器                
即客戶端訪問http://www.cutemsyu.com/uri --> http://192.168.100.1:8080/uri

情況二:URL含有uri

server {
                    ...
                    server_name www.cutemsyu.com;
                    location /uri/ {
                        proxy_pass http://192.168.100.1:8080/new_uri/;
                    }
                    ...
                }
nginx對(duì)于此種情況的處理方式是,將location中的uri替換成proxy_pass指令中URL含有的uri            
即客戶端訪問http://www.cutemsyu.com/uri --> http://192.168.100.1:8080/new_uri

情況三:如果location定義的uri使用正則方式,則URL中不可帶uri

1.2 proxy_set_header field

作用域Context: http, server, location

syntax:proxy_set_header field value;

設(shè)定發(fā)往后端服務(wù)器的請(qǐng)求報(bào)文的請(qǐng)求首部值
使用該指令將客戶端IP傳遞給后端服務(wù)器以日志形式記錄下來,具體做法如下

proxy_set_header X-Real-IP $remote_addr
更改后端服務(wù)器日志記錄客戶端訪問IP字段值為首部X-Real-IP即可
1.3 超時(shí)時(shí)長指令

作用域Context: http, server, location

proxy_connect_timeout time;
定義與后端服務(wù)器建立連接的超時(shí)時(shí)長,默認(rèn)60s

proxy_read_timeout time;
與keep_alived相關(guān)。定義讀取來自后端服務(wù)器響應(yīng)間隔的超時(shí)時(shí)長,不是讀取一次完整的響應(yīng)的時(shí)長,如果在這段時(shí)間內(nèi)沒有任何傳輸動(dòng)作則斷開連接,默認(rèn)60s

proxy_send_timeout time;
與keep_alived相關(guān)。定義向后端服務(wù)器發(fā)送請(qǐng)求的間隔超時(shí)時(shí)長,不是發(fā)送一次完整請(qǐng)求的時(shí)長,如果在這段時(shí)間內(nèi)沒有任何傳輸動(dòng)作則斷開連接,默認(rèn)60s

1.4 proxy_ignore_client_abort

作用域Context: http, server, location

syntax:proxy_ignore_client_abort on | off;

定義nginx與后端服務(wù)器的連接是否中斷,如果客戶端不等待響應(yīng)結(jié)果中斷連接。
該指令默認(rèn)值是off,如果客戶端中斷了連接,nginx與后端連接隨之中斷,nginx記錄5XX的錯(cuò)誤,一般此種錯(cuò)誤很難排查,當(dāng)值設(shè)定為on時(shí),nginx不會(huì)提前中斷與后端服務(wù)器連接,返回的狀態(tài)碼正常記錄200等等,nginx日志也不出現(xiàn)怪異的5XX錯(cuò)誤。

2、nginx服務(wù)器組的配置

模塊ngx_http_upstream_module
該模塊定義可以被 proxy_pass, fastcgi_pass, uwsgi_pass, scgi_pass, and memcached_pass 等指令引用的一組服務(wù)器。
nginx作為反向代理服務(wù)器經(jīng)常要配置一組服務(wù)器,以實(shí)現(xiàn)負(fù)載均衡。當(dāng)定義好一組服務(wù)器時(shí),默認(rèn)調(diào)度算法為輪詢算法,nginx將接收到的請(qǐng)求輪詢發(fā)送給各個(gè)后端服務(wù)器處理,也可以根據(jù)服務(wù)器性能增加權(quán)重,或使用其他調(diào)度算法。

2.1 upstream配置塊

首先在http配置塊中創(chuàng)建新的配置上下文upstream并命名:

http{
    ...
    upstream group_name {
        ...
        ...
    }
    ...
}

接下來介紹upstream中可用的指令

2.2 server指令
syntax:server address [parameters...];

server指令為核心指令,定義組成員
address可用表示形式:

IP[: PORT]

HOSTNAME [ : PORT]

unix: /PATH/TO/SOME_SOCK_FILE

parameters可用如下:

weight=number
定義一個(gè)server的權(quán)重,默認(rèn)為1。權(quán)重高的server優(yōu)先處理請(qǐng)求,并分配更多的請(qǐng)求,即帶權(quán)重的輪詢調(diào)度。

max_fails=number
定義一個(gè)server在一段時(shí)間內(nèi)最大的請(qǐng)求失敗的次數(shù),超過此值,標(biāo)記該server為無效停止提供服務(wù)

fail_timeout=time
有兩層含義:1.此超時(shí)時(shí)長即為在max_fails提到的一段時(shí)間。2.一旦某server標(biāo)記為無效后,在這段時(shí)間內(nèi)不再檢測(cè)。默認(rèn)值為10s

backup
標(biāo)記server為備用服務(wù)器,只有當(dāng)其他服務(wù)器不可用時(shí)才啟用該服務(wù)器

down
標(biāo)記server為無效。一般在升級(jí)服務(wù)時(shí)使用,采用灰度模型將服務(wù)器逐個(gè)從線上脫離。

2.3 幾個(gè)調(diào)度算法

除了默認(rèn)的輪詢調(diào)度算法,還可以采用以下算法,使用方法很簡單——直接添加在upstream中。

least_conn
定義一組服務(wù)器的調(diào)度算法為最少連接數(shù)調(diào)度。根據(jù)server已建立的活動(dòng)連接的數(shù)量來分配請(qǐng)求,擁有最少連接的server優(yōu)先分配。此算法權(quán)重有效

ip_hash
源地址hash調(diào)度算法,來自同一IP的請(qǐng)求總是分配到同一server上。該算法可在較粗的粒度上實(shí)現(xiàn)會(huì)話粘性,實(shí)現(xiàn)會(huì)話保持功能,但一般不采用。

hash key [ consistent ];
基于指定的key的hash表來實(shí)現(xiàn)對(duì)請(qǐng)求的調(diào)度,將同一類請(qǐng)求發(fā)往同一server上,key可以為文本,變量或是二者組合。

可選consistent參數(shù),指一致性hash算法,啟用此參數(shù)可避免一組服務(wù)器增減可用server時(shí)導(dǎo)致hash對(duì)應(yīng)表發(fā)生巨大變動(dòng),減少影響范圍。
示例:

hash $request_uri consistent; #hash請(qǐng)求uri來調(diào)度請(qǐng)求,并選擇一致性hash算法
2.4 服務(wù)器組保持空閑連接數(shù)
syntax:keepalive connections;

該指令設(shè)定每個(gè)worker進(jìn)程為一個(gè)服務(wù)器組保持的空閑連接數(shù)量上限。connections為設(shè)定的數(shù)量,該數(shù)量不宜過大,防止新網(wǎng)絡(luò)連接的建立
該指令使用還是有些麻煩的,參考官網(wǎng)例子如下

#http類型服務(wù)器組啟用時(shí),添加版本1.1,清空Connection首部值
upstream http_backend {
    server 127.0.0.1:8080;

    keepalive 16;
}

server {
    ...

    location /http/ {
        proxy_pass http://http_backend;
        proxy_http_version 1.1;
        proxy_set_header Connection "";
        ...
    }
}

#FastCGI服務(wù)器組時(shí),需設(shè)定fastcgi_keep_conn為on
upstream fastcgi_backend {
    server 127.0.0.1:9000;

    keepalive 8;
}

server {
    ...

    location /fastcgi/ {
        fastcgi_pass fastcgi_backend;
        fastcgi_keep_conn on;
        ...
    }
}
3、nginx代理緩沖

proxy buffer啟用之后,nginx會(huì)以異步形式將后端服務(wù)器返回的數(shù)據(jù)傳遞給客戶端。
nginx首先盡量接收來自后端服務(wù)器的一次響應(yīng)數(shù)據(jù),保存到緩沖區(qū)中,如果接收數(shù)據(jù)超出緩沖區(qū)大小,則保存到本地定義的臨時(shí)文件中。當(dāng)一次數(shù)據(jù)接收完或者緩沖區(qū)已裝滿數(shù)據(jù)則向客戶端發(fā)送數(shù)據(jù)。每個(gè)buffer裝滿數(shù)據(jù)之后向客戶端發(fā)送數(shù)據(jù)直到發(fā)送完成,buffer處于busy狀態(tài),期間對(duì)它進(jìn)行任何其他操作都會(huì)失敗。
以下指令作用域Context: http, server, location

3.1 proxy_buffering
syntax: proxy_buffering on | off;

代理緩沖控制指令,默認(rèn)開啟

3.2 proxy_buffers
syntax: proxy_buffers number size;

該指令配置用于一個(gè)與后端服務(wù)器連接上的buffer數(shù)量,每個(gè)buffer大小。通常size為內(nèi)存分頁大小。接受一次后端服務(wù)器數(shù)據(jù)緩沖總大小為 number*size

3.3 proxy_busy_buffers_size
syntax: proxy_busy_buffers_size size;

該指令設(shè)置同時(shí)處于busy狀態(tài)的buffer總大小。默認(rèn)為proxy_buffers 中定義的size的兩倍。

3.4 proxy_temp_path
syntax: proxy_temp_path path [level1 [level2 [level3]]];

該指令配置用于接收后端服務(wù)器響應(yīng)大體積數(shù)據(jù)的臨時(shí)文件的存儲(chǔ)路徑
Example:

proxy_temp_path /spool/nginx/proxy_temp 1 2;
3.5 proxy_max_temp_file_size
syntax: proxy_max_temp_file_size size;

該指令設(shè)置臨時(shí)文件占用空間的總大小

4、 nginx代理緩存

nginx不是專業(yè)的緩存服務(wù)器,varnish等服務(wù)更加高效,但nginx的緩存功能在某些場(chǎng)景也可發(fā)揮不錯(cuò)的效果。
在上一小節(jié)中我們講到了nginx緩沖,緩沖是為了協(xié)調(diào)不同傳輸效率的設(shè)備之間的傳輸,降低效率高的一方的等待時(shí)間。而本節(jié)將的緩存則是為了提高響應(yīng)客戶端速度,將經(jīng)常訪問的數(shù)據(jù)緩存到本地,當(dāng)客戶端訪問同一資源時(shí)直接將本地存儲(chǔ)的內(nèi)容響應(yīng)給客戶端,減少對(duì)后端服務(wù)器的壓力提高響應(yīng)速度。
同時(shí)nginx的緩沖功能依賴nginx緩沖

4.1 proxy_cache
syntax: proxy_cache zone|off;

該指令配置一塊公用的緩存區(qū)域名稱或者關(guān)閉緩存功能。緩存區(qū)域存放緩存的索引數(shù)據(jù)。

4.2 proxy_cache_key
syntax: proxy_cache_key string;

定義用于建立索引的“鍵”
默認(rèn)值為proxy_cache_key $scheme$proxy_host$request_uri;

4.3 proxy_cache_path

特別指出該指令作用域Context: http

syntax:proxy_cache_path path [levels=levels]  keys_zone=name:size;

該指令定義緩存數(shù)據(jù)的存儲(chǔ)路徑及緩存索引的有關(guān)內(nèi)容。指令比較復(fù)雜上面的用法是縮減版,保留需要配置的參數(shù),其他保持默認(rèn)值即可。
參數(shù)含義:

path 定義存儲(chǔ)根路徑

levels=levels 定義在相對(duì)與path路徑下的第幾級(jí)hash路徑下緩存數(shù)據(jù)

keys_zone=name:size 定義緩存索引存放的區(qū)域和使用大小

4.4 proxy_cache_min_uses
syntax: proxy_cache_min_uses number;

該指令定義一個(gè)資源最少被訪問多少次將其緩存,默認(rèn)值為1

4.5 proxy_cache_use_stale
syntax:proxy_cache_use_stale error | timeout | invalid_header | updating | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | off ...;

該指令定義如果nginx訪問后端服務(wù)器過程中出現(xiàn)無法訪問,或者是訪問錯(cuò)誤等情況時(shí),允許哪些狀態(tài)下nginx使用緩存數(shù)據(jù)來響應(yīng)此次客戶端請(qǐng)求。雖然緩存的數(shù)據(jù)有可能已經(jīng)過期,但是對(duì)于網(wǎng)站可用性來講意義重大。默認(rèn)值為off。

4.6 proxy_cache_valid
syntax:proxy_cache_valid [code...] time;

該指令針對(duì)不同http響應(yīng)狀態(tài)來設(shè)置緩存時(shí)長

4.7 proxy_no_cache
syntax:proxy_no_cache sting;

該指令定義哪些情況下不緩存響應(yīng)數(shù)據(jù)。在string中定義的值可以是多個(gè),當(dāng)它們中的值有一個(gè)為非空或非0,此時(shí)不緩存數(shù)據(jù)。string值通常為http協(xié)議中的緩存控制類首部

4.8 一個(gè)配置樣例
http {
    ...
    proxy_cache_path /var/cache/nginx/proxy_cache levels=1:1:1 keys_zone=ncache:256m ;
    ...
}

location / {
    ...
    proxy_cache ncache;
    proxy_cache_valid 200 302 301 1h;
    proxy_cache_valid any 1m;
    proxy_no_cache $cookie_nocache;
    ...
}
5、nginx 的fastcgi模塊

nginx可以反向代理fastcgi協(xié)議的請(qǐng)求,本節(jié)通過一個(gè)例子講解具體使用

location ~* .php$ { #首先是匹配php動(dòng)態(tài)請(qǐng)求

                fastcgi_pass   127.0.0.1:9000;   #設(shè)置后端服務(wù)器地址
                fastcgi_index  index.php;          #設(shè)置默認(rèn)引導(dǎo)頁面
                fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/html$fastcgi_script_name;   #傳遞php資源路徑給fastcgi服務(wù)器
                include        fastcgi_params; #使用nginx默認(rèn)已配置好的其他參數(shù)
            }
6、結(jié)束語

到此為止nginx三篇文章結(jié)束,歡迎大家收藏關(guān)注。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/39423.html

相關(guān)文章

  • 5個(gè)提高Node.js應(yīng)用性能的技巧

    摘要:如果你有一個(gè)高流量的站點(diǎn),提高性能的第一步是在你的前面放一個(gè)反向代理服務(wù)器。使用在一個(gè)已經(jīng)存在的服務(wù)器前做反向代理,作為的一個(gè)核心應(yīng)用,已經(jīng)被用于全世界成千上萬的站點(diǎn)中。 如果你的 node 服務(wù)器前面沒有 nginx, 那么你可能做錯(cuò)了。— Bryan Hughes Node.js 是使用 最流行的語言— JavaScript 構(gòu)建服務(wù)器端應(yīng)用的領(lǐng)先工具 。由于可以同時(shí)提供 web ...

    k00baa 評(píng)論0 收藏0
  • nginx網(wǎng)站性能優(yōu)化(2)】反向代理實(shí)現(xiàn)Apache與Nginx的動(dòng)靜分離(LNMPA)

    摘要:單獨(dú)使用處理大量動(dòng)態(tài)頁面時(shí)容易產(chǎn)生頻繁的錯(cuò)誤。采用能夠更好的解決架構(gòu)中由于方面產(chǎn)生的錯(cuò)誤,同時(shí)能夠以很簡單的方式提供更安全的多用戶多站點(diǎn)環(huán)境。這個(gè)值可以是一個(gè)文本,變量或者它們的組合。在指定的字段中沒有定義時(shí)會(huì)從它的上級(jí)字段繼承。 為什么要使用反向代理 具體請(qǐng)參考這篇博文: 【Linux常識(shí)篇(1)】所謂的正向代理與反向代理 LNMPA 通過Nginx強(qiáng)大的反向代理功能,把動(dòng)態(tài)文件給A...

    liukai90 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<