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

站長資訊網
最全最豐富的資訊網站

Nginx反向代理時保持長連接

【場景描述】

HTTP1.1之后,HTTP協議支持持久連接,也就是長連接,優點在于在一個TCP連接上可以傳送多個HTTP請求和響應,減少了建立和關閉連接的消耗和延遲。

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

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

【要求】

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

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

【保持和 Client 的長連接】

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

【HTTP配置】

默認情況下,nginx已經開啟了對client連接的 keepalive 支持。對于特殊場景,可以調整相關參數。

http {

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

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

                                                  #當達到最大請求數目且所有已有請求結束后,連接被關閉。

                                                  #默認值為100

}
 

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

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

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

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

·【保持和Server的長連接】

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

 

 

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;                        # 設置http版本為1.1

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

}

}

}
 

【upstream配置】

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

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

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

不理解?沒關系,我們來舉個例子:

場景:

有一個HTTP服務,作為upstream服務器接收請求,響應時間為100毫秒。

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

最優情況:

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

我們以0.1s為單位:

1. 我們現在keepalive的值設置為10,每0.1s鐘有1000個連接

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

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

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

第一種情況:

應答非常平穩,但是請求不平穩的時候

4. 第0.3s的時候,我們只有500個請求收到,有500個請求因為網絡延遲等原因沒有進來

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

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

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

第二種情況:

請求非常平穩,但是應答不平穩的時候

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

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

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

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

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

上面的兩種情況說的都是 keepalive 設置的不合理導致Nginx有多次釋放與創建連接的過程,造成資源浪費。

keepalive 這個參數設置一定要小心,尤其是對于 QPS 要求比較高或者網絡環境不穩定的場景,一般根據 QPS 值和 平均響應時間能大致推算出需要的長連接數量。

然后將keepalive設置為長連接數量的10%到30%。

【location配置】

 

 

http {

server {

location / {

proxy_pass http://backend;

proxy_http_version 1.1;                        # 設置http版本為1.1

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

}

}

}
 

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

HTTP1.0不支持keepalive特性,當沒有使用HTTP1.1的時候,后端服務會返回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會等待多長時間來獲得請求的響應

proxy_send_timeout 12s;          #發送請求給upstream服務器的超時時間 

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection $connection_upgrade;

 }

}

}
 

http里面的map的作用是:

讓轉發到代理服務器的 “Connection” 頭字段的值,取決于客戶端請求頭的 “Upgrade” 字段值。

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

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

【補充】

NGINX支持WebSocket。

對于NGINX將升級請求從客戶端發送到后臺服務器,必須明確設置Upgrade和Connection標題。

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

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

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

【注意】

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

繼承順序為:http, server, location。

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

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

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
国产VA免费精品高清在线| 国产仑乱无码内谢| 国产成人精品亚洲日本语言| 国产精品毛片Av无码一区二区| 国产无遮挡又黄又爽不要VIP软| 娇喘潮喷抽搐高潮在线视频| 久久久久久久精品成人热色戒| 美女露 0裸体无挡视频| 漂亮人妻被强中文字幕| 色噜噜狠狠色综合久色AⅤ网黑| 玩乡下黄花小处雏女| 亚洲国产AV无码专区亚洲AV| 伊人久久大香线蕉无码不卡| AV在线亚洲AV 是全亚洲| 俄罗斯VIDEODESEXO极| 国产免费拔擦拔擦8X高清在线人| 精品精品国产高清A毛片| 胯下硕大征服冰山女神| 热99RE6久精品国产首页青柠| 丝瓜草莓秋葵污旧版APP无限看| 亚洲AV成人一区二区三区在线看| 野花高清在线观看免费3中文| CHINA东北女人对话过瘾| 公粗挺进了我的密道在线观看| 国产亚洲日韩一区二区三区| 久久免费看少妇高潮V片特黄| 欧美无人区码卡二卡3卡2022| 四虎影库最新地址| 亚洲乱码中文论理电影| av一区二区三区| 国产精品无码A∨麻豆| 久久久久人妻一区二区三区VR| 青青青伊人色综合久久| 五月丁香伊人久久91视频| 艳妇乳肉豪妇荡乳ⅩXX| 宝贝把腿张开我要添你下边动态图| 国产精品亚洲精品日韩动图| 久久亚洲日韩AV一区二区三区| 日本三级欧美三级人妇视频| 亚洲VA中文慕无码久久AV| 99久久久无码国产精品9| 国产精品涩涩涩视频网站| 久久亚洲精品综合国产仙踪林| 日韩精品无码一区二区三区免费| 亚洲国产精品久久艾草| 99国精产品灬源码1688钻石| 国产人成视频在线观看| 蜜臀AV福利无码一二三| 天堂А√中文在线官网| 伊人伊成久久人综合网| 国产AV无码专区亚洲AV中文| 久久香蕉综合色一综合色88| 上司人妻互换HD无码| 亚洲欧美日韩中文字幕在线一区 | 日韩午夜福利无码专区A| 亚洲精品天堂成人片AV在线播放| 斑马视频电影免费观看| 精品JAVAPARSER乱偷| 日本乱熟人妻精品乱码涩爱| 亚洲欧美一区二区成人片婷婷| 成人AV天堂一二三在线观看| 久久99国产精品成人| 色先锋AV资源中文字幕| 一二三四免费观看在线6| 国产成人无码AⅤ片在线观看视频 国产成人无码AⅤ片在线观看你 | 久久99精品久久久久久动态图| 日韩欧美人妻在线| 一女三黑人玩4P惨叫| 国产精品扒开腿做爽爽爽| 女儿国在线观看免费版高清 | 国产在线精品一品二区| 人妻少妇-嫩草影院| 野花社区免费观看高清在线1日本| 国产成人AV乱码在线观看| 欧美大屁股XXXX高跟欧美黑人| 亚洲国产精品无码中文字满 | 图片 小说 校园 激情 都市| 最新AV片免费网站入口| 精产一二三产区区别在哪| 色欲久久久天天天综合网精品| 中文无码一区二区视频在线播放量 | 欧美日韩国产精品| 亚洲人成人无码WWW影院| 国产精品成人VA在线播放| 欧洲美熟女乱又伦AV| 一本久道视频无线视频| 国产午夜精品理论片A级在线观看| 日本高清无卡码一区二区久久| 在线A毛片免费视频观看| 国色天香一卡2卡3卡4卡| 少妇人妻陈艳和黑人教练| CAOPOREN超碰| 乱妇乱女熟妇熟女网站| 亚洲国产日韩A在线播放| 国产精品久久久久久久久鸭无码 | 亚洲AV无码AV有码AV| 国产AⅤ无码久久丝袜美腿| 漂亮人妻沦陷精油按摩| 中国丰满熟妇XXXX| 精品人妻人人做人人爽夜夜爽| 天天AV天天翘天天综合网| 草莓视频APP在线下载| 年轻老师的滋味5| 一二三四影视在线观看免费视频| 狠狠精品干练久久久无码中文字幕 | 狼人香蕉毛片AV高潮视频| 亚洲欧美日韩另类| 国产在线观看无遮挡无码AⅤ多人| 天天想你免费看西瓜视频| 动漫人物插画动漫人物的视频 | 成熟妇女一区av| 人妻少妇粗大持久满足| 50岁熟妇大白屁股真爽| 蜜桃av中文字幕| 又爽又黄无遮挡高潮视频网站| 久久精品午夜一区二区福利| 亚洲另类人妻小说| 精品国产福利在线观看| 亚洲成AV人片在线观看橙子 | 亚洲AV无码成人精品| 国产熟妇与子伦HD| 西西人体艺术图片| 国产猛进猛出又黄又爽又色| 无码人妻一区二区三区免费 | 多毛熟女HDVIDOS| 搡BBBB搡BBBB搡BBBB| 大学生高潮无套内谢视频| 日本在线观看母与子| 成人精品视频一区二区| 日韩一区精品视频一区二区| 粗大的内捧猛烈进出在线视频 | 人妻无码一区二区三区| 别揉我奶头~嗯~啊~| 日韩VS欧美VS亚洲VS无码| 成人av在线网站| 深夜成人毛片天堂| 关晓彤露内毛黑森林| 挺进邻居漂亮的娇妻| 国产美女裸体无遮挡免费视频| 亚洲AV无码成人精品区在线h| 黑人AV免费电影| 亚洲精品国产AⅤ成拍色拍| 久久99精品久久久久久动态图| 一二三四在线视频社区8| 麻豆星空九一视频在线| 99精品国产兔费观看久久| 人妻少妇伦在线无码| 国产 中文 制服丝袜 另类| 无码少妇一区二区性色AV| 国内精品伊人久久久久777| 亚洲精品无码久久久久不卡| 精品露脸国产偷人在视频| 亚洲综合激情另类专区| 民工把奶头吸得又大又长| らだ天堂√在线WWW| 日韩人妻无码免费视频一区二区三区 | 舌头伸入麻麻两腿之间| 国产午睡沙发系列大全| 亚洲午夜性猛春交XXXX| 牛和人交VIDEOS欧美3D| 超鹏97国语在线| 唔嗯啊欧美一级作爱网站| 久久SE精品一区二区| 77777_亚洲午夜久久多人| 日韩一线无码AV毛片免费| 国产精品成人嫩草影院| 亚洲欧洲精品成人久久曰| 免费A级毛片无码免费视频120 | 做AJ的视频大全电视剧| 日本乱码卡一卡新区入口| 国产美女mv一区二区竹| 亚洲一区二区三区中文字幕在线| 欧美肥妇多毛BBW| 国产成人国拍亚洲精品| 亚洲精品中文字幕久久久久| 蜜桃成人无码区免费视频网站 | 无码人妻精品一区二区三区夜夜嗨 | 久久在精品线影院精品国产| M豆传媒有限公司观看| 无码毛片一区二区三区本码视频 | 国产精品乱子乱XXXX| 亚洲日韩精品A∨片无码| 欧美日韩中文字幕视频不卡一二区| 国产VIVODESHD精品| 亚洲一卡一卡二新区无人区 | 波多野42部无码喷潮| 性饥渴的农村熟妇在线视频| 两根黑人粗大噗嗤噗嗤视频 | 色综合久久久无码中文字幕波多 | 夜夜躁狠狠躁日日躁| 日本五月天婷久久网站| 好男人好视频资源在线播放| 0D0D肥胖老太婆| 脱岳裙子从后面挺进去| 久久久久亚洲AV成人片乱码| 波多野结衣av电影在线观看| 亚洲国产成人久久精品APP| 欧洲一本到卡二卡三卡乱码| 黑人大荫蒂高潮视频| エロドラえもんCOM中文在线|