成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

Nginx反向代理時保持長連接

【場景描述】

HTTP1.1之后,HTTP協(xié)議支持持久連接,也就是長連接,優(yōu)點(diǎn)在于在一個TCP連接上可以傳送多個HTTP請求和響應(yīng),減少了建立和關(guān)閉連接的消耗和延遲。

如果我們使用了nginx去作為反向代理或者負(fù)載均衡,從客戶端過來的長連接請求就會被轉(zhuǎn)換成短連接發(fā)送給服務(wù)器端。

為了支持長連接,我們需要在nginx服務(wù)器上做一些配置。

【要求】

使用nginx時,想要做到長連接,我們必須做到以下兩點(diǎn):
1.從client到nginx是長連接
2.從nginx到server是長連接

對于客戶端而言,nginx其實(shí)扮演著server的角色,反之,之于server,nginx就是一個client。

【保持和 Client 的長連接】

我們要想做到Client與Nginx之間保持長連接,需要:
1.Client發(fā)送過來的請求攜帶”keep-alive”header。
2.Nginx設(shè)置支持keep-alive

【HTTP配置】

默認(rèn)情況下,nginx已經(jīng)開啟了對client連接的 keepalive 支持。對于特殊場景,可以調(diào)整相關(guān)參數(shù)。

http {

keepalive_timeout 120s;        #客戶端鏈接超時時間。為0的時候禁用長連接。

keepalive_requests 10000;    #在一個長連接上可以服務(wù)的最大請求數(shù)目。

                                                  #當(dāng)達(dá)到最大請求數(shù)目且所有已有請求結(jié)束后,連接被關(guān)閉。

                                                  #默認(rèn)值為100

}
 

大多數(shù)情況下,keepalive_requests = 100也夠用,但是對于 QPS 較高的場景,非常有必要加大這個參數(shù),以避免出現(xiàn)大量連接被生成再拋棄的情況,減少TIME_WAIT。
 

QPS=10000 時,客戶端每秒發(fā)送 10000 個請求 (通常建立有多個長連接),每個連接只能最多跑 100 次請求,意味著平均每秒鐘就會有 100 個長連接因此被 nginx 關(guān)閉。

同樣意味著為了保持 QPS,客戶端不得不每秒中重新新建 100 個連接。

因此,如果用netstat命令看客戶端機(jī)器,就會發(fā)現(xiàn)有大量的TIME_WAIT的socket連接 (即使此時keep alive已經(jīng)在 Client 和 NGINX 之間生效)。

·【保持和Server的長連接】

想讓Nginx和Server之間維持長連接,最樸素的設(shè)置如下:

 

 

http {

upstream backend {

  server 192.168.0.1:8080 weight=1 max_fails=2 fail_timeout=30s;

  server 192.168.0.2:8080 weight=1 max_fails=2 fail_timeout=30s;

  keepalive 300; // 這個很重要!

server {

listen 8080 default_server;

server_name “”;

location / {

proxy_pass http://backend;

proxy_http_version 1.1;                        # 設(shè)置http版本為1.1

proxy_set_header Connection “”;      # 設(shè)置Connection為長連接(默認(rèn)為no)}

}

}

}
 

【upstream配置】

upstream中,有一個參數(shù)特別的重要,就是keepalive。

這個參數(shù)和之前http里面的 keepalive_timeout 不一樣。

這個參數(shù)的含義是,連接池里面最大的空閑連接數(shù)量。

不理解?沒關(guān)系,我們來舉個例子:

場景:

有一個HTTP服務(wù),作為upstream服務(wù)器接收請求,響應(yīng)時間為100毫秒。

要求性能達(dá)到10000 QPS,我們需要在nginx與upstream服務(wù)器之間建立大概1000條HTTP請求。(1000/0.1s=10000)

最優(yōu)情況:

假設(shè)請求非常的均勻平穩(wěn),每一個請求都是100ms,請求結(jié)束會被馬上放入連接池并置為idle(空閑)狀態(tài)。

我們以0.1s為單位:

1. 我們現(xiàn)在keepalive的值設(shè)置為10,每0.1s鐘有1000個連接

2. 第0.1s的時候,我們一共有1000個請求收到并釋放

3. 第0.2s的時候,我們又來了1000個請求,在0.2s結(jié)束的時候釋放

請求和應(yīng)答都比較均勻,0.1s釋放的連接正好夠用,不需要建立新連接,且連接池中沒有idle狀態(tài)的連接。

第一種情況:

應(yīng)答非常平穩(wěn),但是請求不平穩(wěn)的時候

4. 第0.3s的時候,我們只有500個請求收到,有500個請求因?yàn)榫W(wǎng)絡(luò)延遲等原因沒有進(jìn)來

 這個時候,Nginx檢測到連接池中有500個idle狀態(tài)的連接,就直接關(guān)閉了(500-10)個連接

5. 第0.4s的時候,我們收到了1500個請求,但是現(xiàn)在池里面只有(500+10)個連接,所以Nginx不得不重新建立了(1500-510)個連接。

 如果在第4步的時候,沒有關(guān)閉那490個連接的話,只需要重新建立500個連接。

第二種情況:

請求非常平穩(wěn),但是應(yīng)答不平穩(wěn)的時候

4. 第0.3s的時候,我們一共有1500個請求收到

 但是池里面只有1000個連接,這個時候,Nginx又創(chuàng)建了500個連接,一共1500個連接

5. 第0.3s的時候,第0.3s的連接全部被釋放,我們收到了500個請求

Nginx檢測到池里面有1000個idle狀態(tài)的連接,所以不得不釋放了(1000-10)個連接

造成連接數(shù)量反復(fù)震蕩的一個推手,就是這個keepalive 這個最大空閑連接數(shù)。

上面的兩種情況說的都是 keepalive 設(shè)置的不合理導(dǎo)致Nginx有多次釋放與創(chuàng)建連接的過程,造成資源浪費(fèi)。

keepalive 這個參數(shù)設(shè)置一定要小心,尤其是對于 QPS 要求比較高或者網(wǎng)絡(luò)環(huán)境不穩(wěn)定的場景,一般根據(jù) QPS 值和 平均響應(yīng)時間能大致推算出需要的長連接數(shù)量。

然后將keepalive設(shè)置為長連接數(shù)量的10%到30%。

【location配置】

 

 

http {

server {

location / {

proxy_pass http://backend;

proxy_http_version 1.1;                        # 設(shè)置http版本為1.1

proxy_set_header Connection “”;      # 設(shè)置Connection為長連接(默認(rèn)為no)

}

}

}
 

HTTP 協(xié)議中對長連接的支持是從 1.1 版本之后才有的,因此最好通過 proxy_http_version 指令設(shè)置為 1.1。

HTTP1.0不支持keepalive特性,當(dāng)沒有使用HTTP1.1的時候,后端服務(wù)會返回101錯誤,然后斷開連接。

而 “Connection” header 可以選擇被清理,這樣即便是 Client 和 Nginx 之間是短連接,Nginx 和 upstream 之間也是可以開啟長連接的。

【另外一種高級方式】

 

 

http {

map $http_upgrade $connection_upgrade {

default upgrade;

” close;

upstream backend {

server 192.168.0.1:8080 weight=1 max_fails=2 fail_timeout=30s;

server 192.168.0.2:8080 weight=1 max_fails=2 fail_timeout=30s;

keepalive 300;

server {

listen 8080 default_server;

server_name “”;

location / {

proxy_pass http://backend;

proxy_connect_timeout 15;      #與upstream server的連接超時時間(沒有單位,最大不可以超過75s)

proxy_read_timeout 60s;          #nginx會等待多長時間來獲得請求的響應(yīng)

proxy_send_timeout 12s;          #發(fā)送請求給upstream服務(wù)器的超時時間 

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection $connection_upgrade;

 }

}

}
 

http里面的map的作用是:

讓轉(zhuǎn)發(fā)到代理服務(wù)器的 “Connection” 頭字段的值,取決于客戶端請求頭的 “Upgrade” 字段值。

如果 $http_upgrade沒有匹配,那 “Connection” 頭字段的值會是upgrade。

如果 $http_upgrade為空字符串的話,那 “Connection” 頭字段的值會是 close。

【補(bǔ)充】

NGINX支持WebSocket。

對于NGINX將升級請求從客戶端發(fā)送到后臺服務(wù)器,必須明確設(shè)置Upgrade和Connection標(biāo)題。

這也算是上面情況所非常常用的場景。

HTTP的Upgrade協(xié)議頭機(jī)制用于將連接從HTTP連接升級到WebSocket連接,Upgrade機(jī)制使用了Upgrade協(xié)議頭和Connection協(xié)議頭。

為了讓Nginx可以將來自客戶端的Upgrade請求發(fā)送到后端服務(wù)器,Upgrade和Connection的頭信息必須被顯式的設(shè)置。

【注意】

在nginx的配置文件中,如果當(dāng)前模塊中沒有proxy_set_header的設(shè)置,則會從上級別繼承配置。

繼承順序?yàn)椋篽ttp, server, location。

如果在下一層使用proxy_set_header修改了header的值,則所有的header值都可能會發(fā)生變化,之前繼承的所有配置將會被丟棄。

所以,盡量在同一個地方進(jìn)行proxy_set_header,否則可能會有別的問題。

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
久久伊人五月丁香狠狠色| 精品少妇人妻AV无码专区| 国产亚洲AV浪潮A∨尹人Av| 国产又爽又粗又猛的视频| 经典WC偷窥美女如厕MP4| 精品国产一区二区三区久久影院 | 亚洲熟妇无码AV| 日韩精品无码人成视频手机| 少妇人妻中文字幕| 亚洲A∨无码无在线观看| 亚洲人成色777777精品音频| 又爽又黄又无遮挡激情视频免费| GV天堂GV无码男同在线观看| 成熟交BGMBGMBGM| 国产无套内射普通话对白| 精品人妻码一区二区三区| 男吃奶玩乳尖高潮视频午夜| 日本精品一区二区三区在线视频| 无码少妇一区二区浪潮AV| 亚洲色丰满少妇高潮| 51精品国产人成在线观看| 国产男女猛烈无遮挡免费视频| 国语精品自产拍在线观看网站| 久久婷婷五月综合色欧美| 欧美性猛交XXXX乱大交3| 天天摸天天碰天天添| 亚洲欧美一区二区成人片婷婷| 亚洲乱亚洲乱妇无码麻豆| 99久久亚洲综合精品成人| 成人免费AV一区二区三区| 国产乱妇乱子在线播视频播放网站| 九九九精品成人免费视频| 欧美性XXXXX极品| 无码人妻精品一区二区三区东京热| 亚洲AV无码一区二区三区网址| 永久免费观看美女裸体的网站| 波多野结衣乳巨码无在线| 国产日韩AV免费无码一区二区三| 乱人伦中文字幕在线| 大胸美女污污污WWW网站| 国产亚洲大尺度无码无码专线 | 扒开腿狂躁女人爽出白浆| 国产老熟女八AV| 免费人成无码大片在线观看| 天天躁日日躁狠狠躁欧美老妇小说| 亚洲一级性爱视频| 被添高潮爱爱免费视频| 极品少妇被扒开双腿躁出白小说| 欧美中日韩免费观看网站| 西西人体大胆WWW.4444| 色欲av蜜臀一区二区三区vr | 国产午夜激无码AV片在线观看 | 狠狠综合久久AV一区二区| 欧美日韩人妻一区二区| 亚洲AV无码乱码精品国产按摩| 777国产偷窥盗摄精品品在线| 国产极品熟女沙发内射AV| 蜜臀久久99精品久久久久久小说| 天天摸天天透天天添| 中文字幕无码人妻丝袜| 国产一区二区精品久久| 欧美最猛黑人xxxx黑人猛交| 亚洲精品白浆高清久久久久久| 把她送上一个又一个巅峰| 久久精品成人免费国产片| 日产乱码一二三区别免费观看 | 毛茸茸的中国女BBW| 西西444WWW无码大胆| YY8男人的天堂| 久久精品国产99国产精品澳门| 色欲午夜无码久久久久久 | 日本丰满熟妇×××××乱| 亚洲欧洲专线一区| 国产VA免费精品高清在线| 内地性生生活影视大全| 妺妺窝人体色WWW网| 亚洲AV无码成人片在线观看 | 99国产欧美精品久久久蜜芽| 黑人巨大粗物挺进了少妇| 久久精品麻豆日日躁夜夜躁| 手机国产乱子伦精品视频| 99久久免费精品高清特色大片 | 人妻 日韩 欧美 综合 制服| 国内精品一线二线三线黄| 欧美熟妇另类久久久久久不卡| 亚洲AV成人深夜一区午夜网站| 亚洲AV一二三又爽又色又色| 成人影院永久免费观看网址| 免费高清AV一区二区三区| 亚洲国产精品无码久久一线| 国产成人人人97超碰超爽8| 公翁的粗大放进我的秘密电影| 美女床上喷水在线观看| 亚洲国产群交无码AV| 国产精品麻豆VA在线播放| 日韩AV无码中文无码不卡电影| 性欧美玩弄性少妇HD| 丰满岳跪趴高撅肥臀| 欧美熟老妇人多毛OOXⅩ| 在线观看内射亲妹妹无套内射| 黑人高潮拔也拔不出来| 无码人妻一区二区三区免费手机| 成 人 黄 色 网站 69| 欧美成人片一区二区三区| 伊人久久大香线蕉成人| 精品国产乱码久久久软件下载| 无线乱码A区B区C区D| 国产成人精品一区二区三区| 日韩无码视频二区| 被三个男人躁一夜好爽小说| 欧美成人A猛片在线观看| 曰批免费视频播放免费| 久久久AV波多野一区二区| 亚洲精品乱码久久久久久按摩| 国产亚洲精品国产福APP| 无码熟妇人妻AV在线网站| 国产成人愉拍精品| 天堂8中文在线最新版在线| 俄罗斯VODAFONEWIFI| 日本夜爽爽一区二区三区| 办公室撕开奶罩揉吮奶头H文| 欧美人C交ZOOZOOXX| 亚洲AV成人片色在线观看蜜臀| 国产成人亚洲欧美二区综合| 熟女内射婷婷直播| 粉嫩av一区二区网站入口| 色妓AV人妻一区二区三区| 波多野结衣人妻女教师4| 人与畜禽共性关系的重要性有哪些 | 色欲人妻AAAAAAA无码| 成在人线AV无码免费| 日日摸夜夜添无码无码AV| 吃了继兄开的药我做的梦更| 日韩国产成人无码AV毛片蜜柚| 粗大黑人巨茎大战欧美成人免费看| 人人澡人人透人人爽| 俄罗斯女人与马Z00Z视频| 他的粗大把她捣出白沫| 国产精品三级一区二区| 无码人妻精一区二区三区老牛| 国产乱码一卡二卡3卡4卡网站| 亚洲AV成人片色在线观看| 教室别恋在线观看| 一本久道综合在线无码88| 男生和女生在一起差差差| YY6080久久亚洲精品| 少妇高清一区二区免费看| 国产欧美一区二区三区在线看| 亚洲VA欧美VA天堂V国产综合| 娇喘潮喷抽搐高潮在线观看视频| 亚洲欧美日韩中文字幕一区二区三| 久久亚洲AV成人无码国产最大 | 欧美在线视频二区| 粉嫩小泬无遮挡久久久久久小说| 铜铜铜铜铜铜铜铜好大好硬| 国精产品一区二区三区糖心269 | 玩弄漂亮少妇高潮大叫| 含羞草传媒每天免费三次看剧| 亚洲人成国产精品无码果冻| 美女扒开腿让男人桶爽30分钟| CHINESE熟女老女人HD视频| 少妇AV一区二区三区无码久久 | 成人免费777777被爆出| 无遮挡边吃摸边吃奶边做| 久久精品国产亚洲AV麻豆网站| 18禁美女裸体网站无遮挡| 日韩A∨精品日韩在线观看| 国产农村妇女精品一二区| 亚洲色偷偷色噜噜狠狠99网 | 99在线精品国自产拍| 日产中文字幕在线精品一区| 国产无遮挡裸体免费视频在线观看| 亚洲欧美国产精品专区久久| 内射丰满熟妇18p一区二区| 俄罗斯POMOGISEBE| 亚洲国产成人精品无码区在线观看| 邻居少妇很紧毛多水多| 亚洲AV老熟妇在线观看| 久久久一本精品99久久精品66| CAOPORN免费视频在线| 无码国产精品久久一区免费| 久久久久亚洲AV成人网人人网站| www.AV无码| 亚洲AV成人精品一区二区三区| 久久午夜无码免费| 厨房丝袜麻麻被后进怀孕| 亚洲成AV人片在线播放无码| 欧美黑人巨大最猛性XXXXX| 国产精品久久久久久久久电影网| 亚洲一区二区三区自拍公司| 日本边做边吃奶AⅤ视频免费| 孩交精品XXXX视频视频| 99在线精品免费视频九九视| 同性男男黄H片在线播放网站| 久久久噜噜噜久久中文福利| 成熟老太毛茸茸BBWBBW| 亚洲日产精品一二三四区| 日本精品成人一区二区三区视频 | 欧美激情在线播放| 国内精品伊人久久久久妇|