成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院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號
人人妻人人澡人人爽人人| 人人婷婷色综合五月第四人色阁 | 中文在线最新版天堂8| 377人体粉嫩噜噜噜| A∨变态另类天堂无码专区| 成人性欧美丨区二区三区| 国产精品XXX大片免费观看| 花火と在线观看动漫免费| 久久久久久妓女精品影院| 男人扒开添女人下部免费视频 | 低调看JRS直播| 国产午夜精品一区二区三区| 久久精品AⅤ无码中文字字幕重口| 蜜桃AV噜噜一区二区三区| 人妻少妇精品无码专区二区| 挺进绝色老师的紧窄小肉| 亚洲国产欧美在线人成长黄瓜| 岳女四人共侍一夫婷婷| 宝贝儿感受到它对你的爱了吗小说| 高潮毛片无遮挡高清免费视频| 国产一区二区三区精品视频| 久久久无码精品国产一区| 欧美人交a欧美精品a∨一区| 少妇被躁爽到高潮无码文| 亚洲AV永久无码精品一区二区| 又粗又大又硬毛片免费看| 播放灌醉水嫩大学生国内精品| 国产露脸ⅩXXXⅩ高清H| 巨胸美乳无码人妻在线| 日韩中文人妻无码不卡| 亚洲高清成人AV电影网站| 69国产成人综合久久精品| 国产成 人 在线观看 亚洲| 精品亚洲国产成人AV制服| 强壮公的侵犯让我高潮不断| 性生生活色欲片性按摩| 综合久久国产九一剧情麻豆| 国产成人MV视频在线观看| 久久久久无码专区亚洲AV| 人妻无码中文字幕永久有效视频| 亚洲AV无码国产精品色午夜| AⅤ日本亚洲欧洲免费| 国产麻花豆剧传媒精品MV| 免费网站看V片在线18禁| 婷婷5月女内射AV| 在线成人看片黄A免费看| 国产成人AV综合久久视色| 老师扒开粉嫩粉嫩的泬| 铜铜铜铜铜铜铜好多水| 中文亚洲AV片在线观看| 丰满少妇女裸体BBW| 久久天天躁夜夜躁狠狠躁2022| 色伦专区97中文字幕| 一面膜上边一面膜下边53分钟| 动性配人ⅩXXXX配| 看黄A大片爽爽影院免费无码| 熟妇人妻久久中文字幕老熟妇| 野花香高清在线观看视频播放免费 | 国产欧美精品一区二区色综合| 免费无码毛片一区二区APP| 性欧美VIDEOFREE高清潮| AV无码专区亚洲AVL在线观看| 国产尤物亚洲精品不卡| 人妻少妇精品视频一区二区三区| 亚洲精品无码少妇30P| 丰满老师少妇久久久久久1| 麻花传媒MV在线播放高清MBA | 国产午夜精品一区二区三区| 秋霞午夜久久午夜精品| 亚洲伊人成无码综合影院| 公交车上噗嗤一声尽根而没| 没有被爱过的女人| 亚洲AV永久无码成人私密按摩| 成人免费A级毛片无码片在线播放| 久久精品国产亚洲AⅤ无码| 天天躁日日躁狠狠躁日日躁| ASS年轻少妇PIC精品| 久久精品国产久精国产思思 | 曰批免费视频播放免费直播| 国产午夜三级一区二区三| 日本体内SHE精高潮| 中文字幕无码精品亚洲资源网久久| 国内精品免费久久久久电影院97 | 花火と在线观看动漫免费| 四虎永久在线精品免费无码| Chinese辽宁人妻4p| 久久人人爽人人爽AV片| 亚洲AV无码蜜臀久久寂寞少妇 | ASS鲜嫩鲜嫩PICS日本| 久久精品人人做人人爽97| 亚洲 精品 综合 精品 自拍 | 色综合久久久久综合体桃花网| 2022色婷婷综合久久久| 久久精品中文闷骚内射| 亚洲AV无码乱码在线| 国产成人亚洲精品无码AV大片| 人妻熟妇乱又伦精品无码专区 | 亚洲欧美另类激情综合区蜜芽| 国产精品日韩欧美一区二区三区| 日本十八禁免费看污网站| chinese人妻无码人妻| 免费AV一区二区三区| 亚洲熟妇无码V在线观看| 激情久久AV一区AV二区AV三| 性ⅩXXX搡XXXX搡| 国产成人精品免费视频网页大全| 日本熟熟妇XXXXX精品熟妇| ているの天堂资源WWW| 欧美黑人巨大video粗暴| 在线天堂新版最新版在线8| 久久久亚洲裙底偷窥综合| 亚洲色成人网站www观看入口| 国内精品久久久久久不卡影院 | 2023国精产品一二二线精华液 | 极品美女扒开粉嫩小泬的视频| 午夜三级A三级三点自慰| 国产精品人成在线播放新网站| 少妇特殊按摩高潮惨叫无码| 刺激交换经历过程小说| 日韩AV无码中文无码不卡电影 | 中文天堂在线WWW最新版官网| 久久婷婷五月综合97色一本一本| 亚洲色欲色欲综合网站色偷偷| 娇小BBW搡BBBB搡BBBB| 亚洲A级成人无码网站| 护士被医生办公室狂玩| 亚洲国产精品久久青草无码| 国内精品久久久久久99| 亚洲AV永久无码精品无码一区二区 | 99精品久久久久久久另类| 欧美成人精品在线| 97久久香蕉国产线看观看| 欧美free叉叉叉叉极品少妇| CSGO未满十八岁能玩多久| 热RE99久久精品国产99热| 爆乳护士HD完整版在线播放| 日韩成人无码一区二区三区| 俄罗斯ZOOM与人性ZOOM| 婷婷五月深深久久精品| 国产人妖视频一区二区| 亚洲成AV人片在线观看| 精品亚洲成AV人在线观看| 亚洲最新无码成AV人| 乱世桃花免费观看完整版高清| 50岁人妻丰满熟妇ΑV无码区| 欧美激情性XXXXX高清真| 部长的夫人的味道中字| 少妇无码AV无码专区线| 国产免费不卡午夜福利在线 | 舔吮着她的乳尖小说| 国产麻豆 9L 精品三级站| 亚洲成A人片在线观看国产| 久久精品国产亚洲ΑV忘忧草| 主人地下室惩罚骚奴的法律后果| 欧美一进一出抽搐大尺度视频 | 无码被窝影院午夜看片爽爽JK| 国产在线视频 | 传媒| 亚洲无熟妇成人无码| 女人大荫蒂毛茸茸视频| 补课老师让我爽了一夜| 同性男男黄网站在线观看国外| 黑巨人的又黑又大又长| 岳打开双腿开始配合交换| 欧美熟妇呻吟猛交XX牲| 丰满亚洲大尺度无码无码专线| 小辣椒AV福利在线网站| 久久久久久精品免费免费软件| 7777精品伊人久久久大香线蕉| 日本无套内射ⅩXXXX人妻在线| 国产精品久久久久久久久电影网 | 成av人片一区二区三区久久| 无码无遮挡在线观看免费| 久爱无码免费视频在线| 99久久精品无码一区二区三区| 少妇被粗大的猛进出69影院| 和教练在车里干了我三次| 18禁白丝JK自慰喷水无码| 视频免费网站入口| 精品人妻系列无码一区二区三区 | 国产人成高清在线视频99最全资| 亚洲少妇吃奶摸下| 人妻无码中文字幕免费视频蜜桃| 国产熟妇XXXXXⅩ性Ⅹ交| 夜夜高潮天天爽欧美| 人人超碰人人超级碰国| 好男人好资源电影在线播放| 51精产国品一二三产区| 丝袜中文人妻无码有码久热| 久久精品第九区免费观看| 锕锕锕锕锕锕~好深啊APP| 性中国妓女毛茸茸视频| 男女无遮挡XX00动态图120| 国产成人亚洲精品青草天美| 一本之道无码一区二区| 日韩爆乳一区二区无码| 精品无人区卡卡卡卡卡二卡三乱码 | 国产在线精品一区二区中文| 中文字幕 亚洲精品 第1页| 天天躁日日躁狠狠躁| 蜜臀AV 国内精品久久久|