簡介
Nginx 是一個高性能的 HTTP 服務器和反向代理服務器.
最常用的兩個功能是反向代理和負載均衡.
反向代理
反向代理是正向代理的反面.
普通的代理服務器是需要用戶主動去設置的, 用戶在自己的電腦上設置并連接代理服務器,
從而可以隱藏自己的 IP, 使得應用服務器不知道客戶端的 IP 地址.
而反向代理是作為應用服務器的代理, 安裝在服務器上. 客戶端實際上訪問的反向代理服務器,
反向代理服務器再去訪問實際的應用服務器, 然后將獲取到的響應傳送給客戶端.

使用 Nginx 配置反向代理非常簡單, 基礎配置如下:
upstream web {
server 127.0.0.1:8081;
}
server {
listen 80;
server_name web.coolcat.com;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
client_max_body_size 5m;
proxy_pass http://web;
}
}
上面的配置文件中設置了一個域名 web.coolcat.com
,
對這個域名的所有請求都會轉發到 http://web
上.
通過配置 upstream
, 我們可以發現, 實際上的流量都被轉發到了
127.0.0.1:8081
上了.
如此一來, 就實現了反向代理.
負載均衡
負載均衡和反向代理是分不開的, 負載均衡通常都是基于反向代理做的.
所謂的負載均衡, 指的是將多個請求轉發到不同的后端服務器上.
upstream web {
server 127.0.0.1:8081;
}
在上面的反向代理配置中, 只設置了一個后端服務器地址,
如果再添加幾個, 就實現了最簡單的負載均衡了.
輪詢
輪詢策略按順序分配請求.
upstream web {
server 192.168.1.1:8081;
server 192.168.1.2:8081;
}
加權輪詢
加權策略按比例分配請求.
upstream web {
server 192.168.1.1:8081 weight=4;
server 192.168.1.2:8081 weight=6;
}
上面的兩個服務器的訪問概率就是四六開.
最少連接
最少連接將請求分配給當前連接數最少的服務器.
upstream web {
least_conn;
server 192.168.1.1:8081;
server 192.168.1.2:8081;
}
ip_hash
來自同一個 IP 的連接都會分配給同一個服務器, 通常用于 會話保持
.
upstream web {
ip_hash;
server 192.168.1.1:8081;
server 192.168.1.2:8081;
}
通用 hash
使用 hash 自定義要計算的 key. 示例中使用請求地址.
可以選擇 consistent
參數可以指定使用一致性哈希算法.
upstream web {
hash $request_uri;
# hash $request_uri consistent;
server 192.168.1.1:8081;
server 192.168.1.2:8081;
}
參考:
Using nginx as HTTP load balancer
Module ngx_http_upstream_module
總結
Nginx 是很常用的代理服務器, 它的功能非常強大, 性能也很好.
更多的資料請參考官方文檔.
當前部分的代碼
作為版本v0.14.0
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 通過nginx反向代理來調試代碼的實現
- Docker中使用Nginx代理多個應用站點的方法
- Nginx正反向代理及負載均衡等功能實現配置代碼實例
- 通過Nginx代理轉發配置實現跨域的方法(API代理轉發)
- 添加Nginx代理配置只允許內部IP訪問的實現方法
- Nginx代理proxy pass配置去除前綴的實現
- 18個運維必知的Nginx代理緩存配置技巧(你都掌握了哪些呢)
- Nginx正向反向代理區別及原理解析