Nginx作为一款高性能的反向代理服务器,提供了强大的负载均衡功能。以下是Nginx负载均衡的详细配置方法:
http {
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
}
server {
listen 80;
location / {
proxy_pass http://backend;
}
}
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 {
fair;
server backend1.example.com;
server backend2.example.com;
}
可以为每个后端服务器设置额外参数:
upstream backend {
server backend1.example.com weight=5 max_fails=3 fail_timeout=30s;
server backend2.example.com backup;
server unix:/tmp/backend3;
}
weight
:权重max_fails
:最大失败次数fail_timeout
:失败超时时间backup
:备用服务器down
:标记服务器不可用Nginx Plus(商业版)提供主动健康检查功能:
upstream backend {
zone backend 64k;
server backend1.example.com;
server backend2.example.com;
health_check interval=5s fails=3 passes=2 uri=/health;
}
对于开源版,可以使用第三方模块或被动健康检查:
upstream backend {
server backend1.example.com max_fails=3 fail_timeout=30s;
server backend2.example.com max_fails=3 fail_timeout=30s;
}
upstream backend {
ip_hash;
server backend1.example.com;
server backend2.example.com;
}
upstream backend {
server backend1.example.com;
server backend2.example.com;
sticky cookie srv_id expires=1h domain=.example.com path=/;
}
http {
upstream backend {
least_conn;
server backend1.example.com weight=3 max_fails=2 fail_timeout=30s;
server backend2.example.com weight=2 max_fails=2 fail_timeout=30s;
server backup.example.com backup;
keepalive 32;
}
server {
listen 80;
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_http_version 1.1;
proxy_set_header Connection "";
}
}
}
以上配置可以根据实际业务需求进行调整和组合使用。