负载均衡是通过将网络流量分发到多个服务器来提高网站可用性、可靠性和性能的技术。Nginx作为高性能的反向代理服务器,可以轻松实现负载均衡功能。
http {
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
}
server {
listen 80;
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
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;
}
upstream backend {
server backend1.example.com;
server backend2.example.com backup;
}
upstream backend {
server backend1.example.com slow_start=30s;
server backend2.example.com;
}
http {
upstream backend {
least_conn;
server 192.168.1.100:8080 weight=3 max_fails=2 fail_timeout=30s;
server 192.168.1.101:8080 weight=2;
server 192.168.1.102:8080 backup;
keepalive 32;
}
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
proxy_http_version 1.1;
proxy_set_header Connection "";
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;
}
}
}
通过合理配置Nginx负载均衡,可以显著提高网站的可用性和性能,同时为系统提供更好的扩展性和容错能力。