欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解nginx代理socket.io服務(wù)踩坑

 更新時間:2018年10月30日 08:35:37   作者:youmai の Blog  
這篇文章主要介紹了詳解nginx代理socket.io服務(wù)踩坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

nginx代理了兩臺socket.io服務(wù)器。socket.io的工作模式是polling升級到websocket

現(xiàn)象

通過nginx請求服務(wù)時,出現(xiàn)了大量的400錯誤,有時候能升級到websocket,有時候會一直報錯。但是直接通過 ip+端口 訪問時,100%能成功。

分析

sid

sid是我們這個問題的關(guān)鍵。在初始創(chuàng)建連接時(polling模式就是在模擬一個長連接),客戶端會發(fā)起這樣的請求:

https://***/?EIO=3&transport=polling&t=1540820717277-0

服務(wù)端收到后會創(chuàng)建一個對象,綁定在這個連接上,同時返回一個sid(session id),來標(biāo)記這個會話。會話指什么呢,會話是一連串的交互,這些交互之間是有聯(lián)系的,在我們這個場景下就是,下一次的http請求到來,我需要找到之前綁定在理論上的長連接(這里還沒有websocket,所以是理論上的)上的那個對象。我們知道http請求是無狀態(tài)的,每個請求之間獨立,所以socket.io引入了sid來做這件事。服務(wù)端收到請求后會生成一個sid,看下response:

復(fù)制代碼 代碼如下:
{"sid":"EoGaL3fRQlpTOaLp5eST","upgrades":["websocket"],"pingInterval":8000,"pingTimeout":10000}

之后每次請求都需要帶上這個sid,建立websocket請求的連接也不例外。所以說,sid是polling,以及polling升級到websocket的關(guān)鍵。這之后的請求類似于:

https://***/?EIO=3&transport=polling&t=1540820717314-1&sid=EoGaL3fRQlpTOaLp5eST

or

wss://***/?EIO=3&transport=websocket&t=1540820717314-1&sid=EoGaL3fRQlpTOaLp5eST

那么問題來了,如果請求是帶上的sid不是服務(wù)端生成的會怎樣呢?服務(wù)端會不認識,給你返回一個400,并告訴你

invalid sid

我們遇到的便是這個問題,nginx默認的負載均衡策略是輪詢,所以請求有可能會打到不是生成這個sid的機器上去,這時候我們就會收到一個400,如果運氣好,可能也會打到原來的機器上,運氣更好一點,甚至能堅持到websocket連接建立。

解決

這里提出兩種方案

  1. nginx的負載均衡采用ip_hash,這樣能保證一個客戶端的請求都走到一臺服務(wù)器上
  2. 不使用polling模式,只使用websocket

這兩種方案各有利弊。第二種顯而易見,不支持websocket的古老瀏覽器和客戶端將沒法工作。第一種的問題隱藏得比較深,試想,如果你增減了機器會怎樣,這時候ip_hash策略的模將變化,之前的連接將全部失效,而對于微服務(wù),擴縮容是很頻繁的操作(特別是產(chǎn)品處于發(fā)展期),這種有損的擴縮容很大概率是不能接受的。

綜上,建議直接使用websocket,畢竟不支持websocket的老版本占比很少,而且相對于先polling,耗時也會減少。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Nginx跨域訪問配置方式(Web反向代理跨域訪問配置)

    Nginx跨域訪問配置方式(Web反向代理跨域訪問配置)

    這篇文章主要介紹了Nginx跨域訪問配置方式(Web反向代理跨域訪問配置),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Nginx轉(zhuǎn)發(fā)socket端口配置詳解

    Nginx轉(zhuǎn)發(fā)socket端口配置詳解

    這篇文章主要介紹了Nginx轉(zhuǎn)發(fā)socket端口配置詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • Nginx下SSL證書安裝部署步驟介紹

    Nginx下SSL證書安裝部署步驟介紹

    大家好,本篇文章主要講的是Nginx下SSL證書安裝部署步驟介紹,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下哦,方便下次瀏覽
    2021-12-12
  • Nginx實現(xiàn)流量控制的示例代碼

    Nginx實現(xiàn)流量控制的示例代碼

    本文主要介紹了Nginx實現(xiàn)流量控制的示例代碼,可以用來限制用戶在給定時間內(nèi)HTTP請求的數(shù)量,保護服務(wù)器,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • Nginx+CI框架出現(xiàn)404錯誤怎么解決

    Nginx+CI框架出現(xiàn)404錯誤怎么解決

    這篇文章主要介紹了Nginx+CI出現(xiàn)404錯誤怎么解決的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • Nginx單IP地址配置多個SSL證書的方法示例

    Nginx單IP地址配置多個SSL證書的方法示例

    這篇文章主要介紹了Nginx單IP地址配置多個SSL證書的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • CentOS6.6 安裝 Tengine 筆記

    CentOS6.6 安裝 Tengine 筆記

    這篇文章主要介紹了CentOS6.6 安裝 Tengine 筆記,本文講解了安裝必要的編譯環(huán)境好、安裝需要的組件、安裝Tengine等步驟,需要的朋友可以參考下
    2015-03-03
  • 權(quán)限問題導(dǎo)致Nginx 403 Forbidden錯誤的解決方法

    權(quán)限問題導(dǎo)致Nginx 403 Forbidden錯誤的解決方法

    這篇文章主要介紹了權(quán)限問題導(dǎo)致Nginx 403 Forbidden錯誤的解決方法,本文中導(dǎo)致 403 Forbidden錯誤的原因是配置文件中沒有指明一個用戶,需要的朋友可以參考下
    2014-08-08
  • 使用Nginx配置瀏覽器緩存,頁面展示更快一步

    使用Nginx配置瀏覽器緩存,頁面展示更快一步

    這篇文章主要介紹了使用Nginx配置瀏覽器緩存,頁面展示更快一步問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Nginx反向代理location和proxy_pass配置規(guī)則詳細總結(jié)

    Nginx反向代理location和proxy_pass配置規(guī)則詳細總結(jié)

    nginx代理訪問很好用,但是好多人不清楚location和proxy_pass組合在一起使用時訪問的url被代理的url真實地址是什么,下面這篇文章主要給大家介紹了關(guān)于Nginx反向代理location和proxy_pass配置規(guī)則的相關(guān)資料,需要的朋友可以參考下
    2022-09-09

最新評論