本篇文章為大家展示了如何在nginx中反向代理webSocket,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
創(chuàng)新互聯(lián)不只是一家網(wǎng)站建設的網(wǎng)絡公司;我們對營銷、技術、服務都有自己獨特見解,公司采取“創(chuàng)意+綜合+營銷”一體化的方式為您提供更專業(yè)的服務!我們經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。我們珍視每一份信任,關注我們的成都網(wǎng)站設計、成都網(wǎng)站建設、外貿網(wǎng)站建設質量和服務品質,在得到用戶滿意的同時,也能得到同行業(yè)的專業(yè)認可,能夠為行業(yè)創(chuàng)新發(fā)展助力。未來將繼續(xù)專注于技術創(chuàng)新,服務升級,滿足企業(yè)一站式營銷型網(wǎng)站需求,讓再小的品牌網(wǎng)站設計也能產生價值!
GET /chat HTTP/1.1 Host: server.example.com Upgrade: websocket Connection: Upgrade Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw== Sec-WebSocket-Protocol: chat, superchat Sec-WebSocket-Version: 13 Origin: http://example.com
熟悉HTTP的童鞋可能發(fā)現(xiàn)了,這段類似HTTP協(xié)議的握手請求中,只是多了幾個東西。
Upgrade: websocket Connection: Upgrade 這個就是Websocket的核心了,告訴Apache、Nginx等服務器:我發(fā)起的是Websocket協(xié)議。 Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw== Sec-WebSocket-Protocol: chat, superchat Sec-WebSocket-Version: 13
首先,Sec-WebSocket-Key 是一個Base64 encode的值,這個是瀏覽器隨機生成的,告訴服務器:泥煤,不要忽悠窩,我要驗證尼是不是真的是Websocket助理。
最后,Sec-WebSocket-Version 是告訴服務器所使用的Websocket Draft(協(xié)議版本),在最初的時候,Websocket協(xié)議還在 Draft 階段,各種奇奇怪怪的協(xié)議都有,而且還有很多期奇奇怪怪不同的東西,什么Firefox和Chrome用的不是一個版本之類的,當初Websocket協(xié)議太多可是一個大難題。。不過現(xiàn)在還好,已經(jīng)定下來啦 大家都使用的一個東西
然后服務器會返回下列東西,表示已經(jīng)接受到請求, 成功建立Websocket啦!
HTTP/1.1 101 Switching Protocols Upgrade: websocket Connection: Upgrade Sec-WebSocket-Accept: HSmrc0sMlYUkAGmm5OPpG2HaGWk= Sec-WebSocket-Protocol: chat
這里開始就是HTTP最后負責的區(qū)域了,告訴客戶,我已經(jīng)成功切換協(xié)議啦~
Upgrade: websocket Connection: Upgrade
依然是固定的,告訴客戶端即將升級的是Websocket協(xié)議。至此,HTTP已經(jīng)完成它所有工作了,接下來就是完全按照Websocket協(xié)議進行了。
明白協(xié)議的原理了就可以下一步了
首先nginx先配置好https的證書
服務器的證書是老大配置好的,我就直接用了。需要的自己查一下吧0.0
在nginx配置文件的 service
節(jié)點中添加如下配置
location /wss { proxy_pass http://127.0.0.1:8888; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; proxy_set_header X-Real-IP $remote_addr; }
解釋一下參數(shù)
/wss
這個是隨便起的,告訴Nginx要代理的url,現(xiàn)在我的設置為 wss
,當我訪問的我的服務器 https://abc.com/wss
時,Nginx會把我的請求映射到本機的8888端口。
proxy_pass
要代理到的url,我的代理到本機的8888端口。
proxy_http_version
代理時使用的 http版本。
重點來了:
代理webSocket的關鍵參數(shù)
proxy_set_header Upgrade
把代理時http請求頭的 Upgrade
設置為原來http請求的請求頭,wss協(xié)議的請求頭為 websocket
proxy_set_header Connection
因為代理的wss協(xié)議,所以http請求頭的 Connection
設置為 Upgrade
proxy_set_header X-Real-IP
給代理設置原h(huán)ttp請求的ip,填寫 $remote_addr
即可
至于websocket協(xié)議的response的參數(shù),在反向代理的時候不用管。
到這里,Nginx反向代理webSocket的配置就完成了,重啟Nginx,用websocket連接試試,在原來wss地址的地方填寫 wss://abc.com/wss
。如果websocket成功連接,說明Nginx反向代理websocket已經(jīng)成功了。
總結
現(xiàn)在的配置只是反向代理到本機時的配置,如果要反向代理到別的主機,在代理時可能會跨域問題,需要在Nginx的反向代理中做跨域的配置。
思考
在Nginx的配置文件中能看到這一段
location ~ .php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
這是Nginx中php的配置文件,我擦,怎么這么眼熟,這個配置清單跟剛才的websocket的反向代理這么像。通過上網(wǎng)查資料才知道,原來Nginx在處理php類型的請求時,把請求發(fā)fastcgi管理進程處理,fascgi管理進程選擇cgi子進程處理結果并返回被nginx,而php-fpm是一個PHP FastCGI管理器,nginx本身不能處理PHP,它只是個web服務器,當接收到請求后,如果是php請求,則發(fā)給php解釋器處理,并把結果返回給客戶端。所以說Nginx在處理php類型的請求時,本質上也是通過反向代理功能實現(xiàn)的。
我們可以把思維展開,用Nginx反向代理可以實現(xiàn)更多的功能,比如代理Tomcat
location /Tomcat { proxy_pass http://127.0.0.1:8080; proxy_http_version 1.1; proxy_set_header X-Real-IP $remote_addr; }
上述內容就是如何在nginx中反向代理webSocket,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。