當今互聯網領域,不論是APP仍是H5,不論是微信端仍是小程序,只要是一款像樣點的產品,爲了增長用戶的交互感和用戶粘度,多多少少都會涉及到聊天功能。而對於Web端與H5來講,實現聊天最簡單的就是使用WebSocket了。而在實現WebSocket聊天的過程當中,後臺也每每會部署多個WebSocket服務,多個WebSocket服務之間,能夠經過Nginx進行負載均衡。今天,咱們就來一塊兒說說Nginx是如何配置WebSocket的。nginx
Nginx配置WebSocket也比較簡單,只須要在nginx.conf文件中進行相應的配置。這種方式很簡單,可是頗有效,可以橫向擴展WebSocket服務端的服務能力。web
先直接展現配置文件,以下所示(使用的話直接複製,而後改改ip和port便可)面試
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
upstream wsbackend{
server ip1:port1;
server ip2:port2;
keepalive 1000;
}
server {
listen 20038;
location /{
proxy_http_version 1.1;
proxy_pass http://wsbackend;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_read_timeout 3600s;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
複製代碼
接下來,咱們就分別分析上述配置的具體含義。小程序
首先:bash
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
複製代碼
表示的是:服務器
若是 $http_upgrade 不爲 '' (空),則 $connection_upgrade 爲 upgrade 。
若是 $http_upgrade 爲 '' (空),則 $connection_upgrade 爲 close。
其次:微信
upstream wsbackend{
server ip1:port1;
server ip2:port2;
keepalive 1000;
}
複製代碼
表示的是 nginx負載均衡:websocket
兩臺服務器 (ip1:port1)和(ip2:port2) 。
keepalive 1000 表示的是每一個nginx進程中上游服務器保持的空閒鏈接,當空閒鏈接過多時,會關閉最少使用的空閒鏈接.固然,這不是限制鏈接總數的,能夠想象成空閒鏈接池的大小,設置的值應該是上游服務器可以承受的。
最後:併發
server {
listen 20038;
location /{
proxy_http_version 1.1;
proxy_pass http://wsbackend;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_read_timeout 3600s;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
複製代碼
表示的是監聽的服務器的配置負載均衡
listen 20038 表示 nginx 監聽的端口
locations / 表示監聽的路徑(/表示全部路徑,通用匹配,至關於default)
proxt_http_version 1.1 表示反向代理髮送的HTTP協議的版本是1.1,HTTP1.1支持長鏈接
proxy_pass http://wsbackend; 表示反向代理的uri,這裏可使用負載均衡變量
proxy_redirect off; 表示不要替換路徑,其實這裏若是是/則有沒有都不要緊,由於default也是將路徑替換到proxy_pass的後邊
Host $host; 表示傳遞時請求頭不變, $host是nginx內置變量,表示的是當前的請求頭,proxy_set_header表示設置請求頭
proxy_set_header X-Real-IP $remote_addr; 表示傳遞時來源的ip仍是如今的客戶端的ip
proxy_read_timeout 3600s; 表的兩次請求之間的間隔超過 3600s 後才關閉這個鏈接,默認的60s,自動關閉的元兇
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 表示X-Forwarded-For頭不發生改變
proxy_set_header Upgrade $http_upgrade; 表示設置Upgrade不變
proxy_set_header Connection $connection_upgrade; 表示若是 $http_upgrade爲upgrade,則請求爲upgrade(websocket),若是不是,就關閉鏈接
好了,今天就聊到這兒吧!別忘了點個贊,給個在看和轉發,讓更多的人看到,一塊兒學習,一塊兒進步!!
若是你以爲冰河寫的還不錯,請微信搜索並關注「 冰河技術 」微信公衆號,跟冰河學習高併發、分佈式、微服務、大數據、互聯網和雲原生技術,「 冰河技術 」微信公衆號更新了大量技術專題,每一篇技術文章乾貨滿滿!很多讀者已經經過閱讀「 冰河技術 」微信公衆號文章,成功跳槽到大廠;也有很多讀者實現了技術上的飛躍,成爲公司的技術骨幹!若是你也想像他們同樣提高本身的能力,實現技術能力的飛躍,進大廠,升職加薪,那就關注「 冰河技術 」微信公衆號吧,天天更新超硬核技術乾貨,讓你對如何提高技術能力再也不迷茫!