要实现两个服务器一个虚拟VIP的双机热备,可以使用Nginx的upstream和keepalive模块。具体配置如下:
定义upstream
upstream myserver {
# 设置服务器1的IP和端口
server 172.16.21.190:9009 max_fails=3 fail_timeout=30s;
# 设置服务器2的IP和端口
server 172.16.21.191:9009 max_fails=3 fail_timeout=30s;
# 开启keepalive功能,保持与后端服务器的TCP连接
keepalive 64;
}
定义server
server {
listen 172.16.21.200:80;
server_name myvip.com;
# 静态资源目录
root /var/www/myvip.com;
# 访问日志和错误日志
access_log /var/log/nginx/myvip.access.log;
error_log /var/log/nginx/myvip.error.log;
# 负载均衡配置
location / {
# 使用upstream中的服务器进行负载均衡
proxy_pass http://myserver;
# 远程服务器返回的HTTP状态码大于等于500时,认为是服务器出错
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
# 启用代理缓存
proxy_cache_bypass $http_pragma;
proxy_cache_revalidate on;
proxy_cache_valid 200 304 12h; # 缓存时间为12小时
proxy_cache_valid 301 302 1h; # 缓存时间为1小时
proxy_cache_valid any 30s; # 其他响应缓存30秒
proxy_cache_key "$host$request_uri";
proxy_cache_min_uses 1;
}
# 配置WebSocket
location /ws {
proxy_pass http://myserver;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
}
# 配置静态资源缓存
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
expires 1d;
add_header Cache-Control "public, max-age=86400";
proxy_cache_bypass $http_pragma;
proxy_cache_revalidate on;
proxy_cache_valid 200 304 12h;
proxy_cache_valid 301 302 1h;
proxy_cache_valid any 30s;
proxy_cache_key "$host$request_uri";
proxy_cache_min_uses 1;
}
# 配置反向代理
location /api {
proxy_pass http://172.16.21.190:8848/api;
}
# 配置反向代理
location /redis {
proxy_pass http://172.16.21.191:20015;
}
}
在上面的配置中,我们定义了一个名为myserver的upstream,它包含了两个后端服务器的IP和端口。我们还定义了一个server,它监听172.16.21.200:80这个虚拟VIP,并将请求转发到myserver这个upstream中进行负载均衡。同时,我们配置了代理缓存、静态资源缓存、反向代理等功能,使得Nginx可以更好地处理HTTP请求。