成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院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號
国产精品无码素人福利不卡| 亚洲AV永久无码成人红楼影视| 特大肥女BBWASS| 小妖精又紧又湿高潮H视频69| 亚洲国产成人久久综合| 一本色道久久88亚洲精品综合 | 被C哭着爬走又被拉回来挺进H| 抽出含了一整夜的性器液体流出| 在线观看日本亚洲一区| 99久久99久久精品免费看蜜桃| 野花日本免费完整版高清版8 | 国产偷自一区二区三区| 久久国产AVJUST麻豆| 年轻的少妇A级伦理| 上面一个奶下面一个顶是什么字| 亚洲AV人无码激艳猛片| 无码AV片在线观看免费| 亚洲精品1卡2卡三卡23卡| 无遮挡粉嫩小泬女视频| 亚洲日韩在线成人AV电影网站| 亚洲AV综合色区| 中文字幕AV一区二区三区人妻少| 被多个男人调教奶头玩奶头| 国产精品无码AV一区二区三区| 久久天天躁狠狠躁夜夜不卡| 日出水了好深好涨| 亚洲AV一二三又爽又色又色| 97国产精华最好的产品| 国产成人精品优优AV| 久久精品麻豆日日躁夜夜躁| 久久精品无码中文字幕老司机| 欧美最猛黑人XXXX黑人猛交98| 无码动漫在线观看漫画| 一本色道久久综合狠狠躁| 当着全班面被C到高潮哭视频 | 国产无遮挡裸露视频免费| 麻批好紧日起要舒服死了| 少妇被又大又粗又爽毛片| 亚洲男人的天堂AV手机在线观看| YY8090韩国理伦片在线| 国偷自产一区二视频观看| 男男H黄动漫啪啪无遮挡网站| 年轻老师的滋味5| 无码国产色欲XXXXX视频| 中文字幕AV在线一二三区| 国产精品导航一区二区| 麻豆视传媒官方直接进入| 无码国产精成人午夜视频一区二区 | 色吊丝AV中文字幕| 亚洲中文字幕无码第一区| 在办公室把护士给爽了动态图| 关晓彤露内毛黑森林| 两人做人爱视频在线观看| 天天做天天爱天天综合网| 中文在线っと好きだった官网| 国产精品久久久久精品| 欧美VIDEOSDESXO孕交| 亚洲VA无码手机在线电影| 差差差很疼30分钟的视频| 久久久久久精品精品免费 | 亚洲综合国产成人无码| 国产成人精品午夜福利在线播放| 男人激烈吮乳吃奶毛片| 亚洲成人片在线观看| 成人综合婷婷国产精品久久| 老师露双奶头无遮挡挤奶视频| 无码熟妇人妻AⅤ在线影片| FUCK东北老熟女人HD叫床| 丰满人妻熟妇乱又伦精品视| 巨爆乳中文字幕巨爆区巨爆乳无码| 无码少妇一区二区三区浪潮av| CAOPORN最新地址| 久久精品亚洲精品无码| 午夜A级成人免费毛片| 把腿张开老子臊烂你的漫画| 看黄A大片日本真人视频直播 | 精品国产成人A区在线观看| 成熟丰满女人丰满妇女aⅴ| 中国老太太WBBHD| 国产在线视频www色| 人人妻人人澡人人爽人人到DVD| 亚洲永久无码7777KKK| 国产精品色视频ⅩXXX| 人妻一本久道久久综合久久鬼色| 曰本女人与公拘交酡| 狠狠噜天天噜日日噜视频麻豆| 上面一个摸下面一个手念什么 | 精品丝袜人妻久久久久久| 精品一区二区三区在线视频| 女人扒开的小泬高潮喷水小说| 亚洲区综合区小说区激情区| 国产乱子伦60女人的皮视频| 日韩精品极品视频在线观看免费| 91麻豆精品无码一区二区三区 | 亚洲性夜夜综合久久7777| 国产熟睡乱子伦视频| 手机在线永久免费观看AV片| 亚洲Av无码一区二区三区大黄瓜| 多毛BGMBGMBGM胖在线| 欧美又粗又长XXXXBBBB疯| 18禁纯肉高黄无码动漫| 国产黄A三级三级三级| 日本55丰满熟妇厨房伦| HEYZO高清中文字幕在线| 男男av在线播放| 最新的美国ZOOM动物| 久久无码AV三级| 亚洲最大AV网站在线观看| 久久精品久久久久久久精品| 亚洲另类无码专区丝袜| 回民丰满少妇XXX性| 亚洲AV无码熟妇在线观看| WWW久久只有这里有精品| 年轻漂亮的人妻被公侵犯BD免费版 | 欧美18VIDEOSEX性欧美| 中文字幕人乱码中文字幕| 麻豆精品一区综合AV在线| 在线观看的AV网站| 美女喷水一区国产| 18一20岁GAYXXⅩ男| 女人扒开的小泬高潮喷水小说| 999久久久免费精品播放| 欧美叉叉叉BBB网站| JIZZ成熟丰满| 人体艺术大胆图片| 成色好的Y31S标准版| 特区爱奴在线观看| 国产成人无码AⅤ片在线观看视频| 免费全部高H视频无码| 中文字幕在线观看亚洲日韩| 男人躁女人到高潮视频| DIPTYQUE含羞草香薰| 日本巨大的奶头在线观看| 中国老熟妇自拍HD发布| 男女作爱免费网站| JΑPΑNESEHD熟女熟妇伦| 日本一道综合久久AⅤ久久| 给丰满丁字裤少妇按摩到高潮| 爽爽AV浪潮AV一区二区| 国产美女精品一区二区三区| 亚洲AV无码蜜臀久久寂寞少妇| 精品国产污污免费网站AⅤ| 野花香电视剧全集免费观看| 妺妺窝人体色WWW聚色窝丿| 亚洲日韩国产一区二区三区| 久久久久无码精品国产AV蜜桃1| 伊人久久精品AV无码一区| 激情无码人妻又粗又大| 亚洲中文在线精品国产| 女班长给我看她小积积作文 | 日韩av一区二区三区| 国产成人无码AA精品一区| 亚洲AV无码国产在丝袜APP| 久久精品国产亚洲AV麻豆小说| 最新国产毛2卡3卡4卡| 日本猛少妇色XXXXX猛叫小说| 国产精品99久久免费| 亚洲国产成人高清在线观看| 麻豆国产精品VA在线观看不卡| GAY2022空少被体育生暴菊| 天天爽夜夜爽夜夜爽精品视频| 国模无码一区二区三区不卡| 有码中文AV无码中文AV| 欧洲熟妇色XXXXX欧美老妇伦| 国产MV高清砖码2022| 亚洲精品偷拍自综合网| 免费一对一真人视频| 丰满人妻被公侵犯日本| 亚洲国产成人综合精品| 女人扒下裤让男人桶到爽| 国产超碰AV人人做人人爽| 亚洲色播爱爱爱爱爱爱爱| 欧洲成人午夜精品无码区久久| 国产精品后入内射日本在线观看| 亚洲一区AV无码少妇电影| 人妻无码AⅤ中文字幕日韩| 国产拍揄自揄精品视频| 中文字幕乱偷无码AV先锋| 熟妇高潮精品一区二区三区| 精品久久8X国产免费观看| AV怡红院一区二区三区| 免费无码高H视频在线观看h| 粉嫩av观看成人网站| 亚洲日韩乱码1区二区| 欧美性色XXⅩXXA片HD| 国产女人18毛片水真多18精品| 长腿校花无力呻吟娇喘| 色欲av伊人久久大香线蕉影院| 精品一区二区无码免费| 超碰人人看人人2017| 亚洲国产婷婷香蕉久久久久久| 奇米影视7777狠狠狠狠影视| 国产亚洲精品在AV| CHINESE国产AVVIDE| 亚洲AV成人无码一区在线观看| 欧美18VIDEOSEX性欧美| 国产亚洲精品第一综合麻豆| IPHONE欧美高级| 亚洲精品天堂无码中文字幕| 日产精品一线二线三线京东|