Nginx是一个高性能的HTTP和反向代理服务器,非常适合用于反向代理和负载均衡配置。以下是详细的使用方法:
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend_server;
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_pass
: 指定后端服务器地址proxy_set_header
: 设置转发给后端服务器的请求头proxy_redirect
: 修改后端服务器返回的Location和Refresh头proxy_buffering
: 控制是否启用响应缓冲proxy_connect_timeout
: 连接后端服务器的超时时间upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
Nginx支持多种负载均衡算法:
upstream backend {
server backend1.example.com;
server backend2.example.com;
}
upstream backend {
server backend1.example.com weight=3;
server backend2.example.com weight=2;
}
upstream backend {
ip_hash;
server backend1.example.com;
server backend2.example.com;
}
upstream backend {
least_conn;
server backend1.example.com;
server backend2.example.com;
}
upstream backend {
server backend1.example.com max_fails=3 fail_timeout=30s;
server backend2.example.com max_fails=3 fail_timeout=30s;
}
http {
upstream backend {
least_conn;
server 192.168.1.100:8080 weight=5;
server 192.168.1.101:8080;
server 192.168.1.102:8080 backup;
}
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
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_connect_timeout 5s;
proxy_read_timeout 60s;
proxy_send_timeout 30s;
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
}
}
}
upstream backend {
server 192.168.1.100:8080;
keepalive 32;
}
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m;
server {
location / {
proxy_cache my_cache;
proxy_cache_valid 200 302 10m;
proxy_cache_valid 404 1m;
}
}
location /ws/ {
proxy_pass http://backend;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
502 Bad Gateway错误:
proxy_connect_timeout
值负载不均衡:
性能问题:
配置完成后,使用nginx -t
测试配置,然后nginx -s reload
重新加载配置。