先直接展示配置文件,如下所示(使用的話直接復制,然后改改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;
}
}
接下來,我們就分別分析上述配置的具體含義。
首先:
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負載均衡:
- 兩台服務器 (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的后邊
- proxy_set_header 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),如果不是,就關閉連接
若是實際使用的websocket地址后面還有路徑,比如實際地址是這樣的,訪問地址是 http://www.a.com,實際會轉發給ws://127.0.0.1:8094/ws
那么配置如下:
http {
......
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
server {
......
location /ws {
proxy_pass http://127.0.0.1:8094/ws;
proxy_read_timeout 300s;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
}
若是上一步中ws地址有多個,則可以這樣做,訪問地址是 http://www.a.com,實際會轉發給ws://126.126.132.197:9080/ws或者ws://126.126.132.195:9080/ws。
nginx日志中的變量upstream_addr只顯示轉發的節點,也就是從camera中選出來的地址。不顯示/ws,但轉過去是帶ws的。也就是說會從camera中選一個地址出來,然后再跟上后面的路徑/ws共同構成實際轉發的地址
http {
......
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
upstream camera {
server 126.126.132.197:9080;
server 126.126.132.195:9080;
}
server {
......
location /ws {
proxy_pass http://camera/ws;
proxy_read_timeout 300s;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
}