要在Nginx中配置upstream反向代理,主要需要修改nginx.conf或在conf.d/目录下创建新的配置文件。以下是基本配置示例:
http {
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
server {
listen 80;
server_name yourdomain.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;
}
}
}
upstream backend {
# 轮询(默认)
server backend1.example.com;
server backend2.example.com;
# 加权轮询
server backend3.example.com weight=3;
# IP哈希(保持会话)
ip_hash;
# 最少连接数
least_conn;
}
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;
server backend2.example.com;
keepalive 32;
}
http {
upstream backend {
least_conn;
server 192.168.1.100:8080 weight=5 max_fails=3 fail_timeout=30s;
server 192.168.1.101:8080 weight=3;
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_set_header X-Forwarded-Proto $scheme;
# 超时设置
proxy_connect_timeout 5s;
proxy_send_timeout 10s;
proxy_read_timeout 10s;
# 缓冲设置
proxy_buffering on;
proxy_buffer_size 4k;
proxy_buffers 8 16k;
proxy_busy_buffers_size 32k;
}
}
}
nginx -t
nginx -s reload
希望这个配置指南对您有所帮助!如需更具体的配置建议,请提供您的具体需求场景。