问题陈述: 我想使用nginx plus设置主动故障转移(我订阅了30天试用版)。 所有服务器都应该转到主服务器,如果发生故障(404),那么请求应该转到第二台服务器。主服务器启动后,请求应返回原始服务器。可能吗? 在其他线程的帮助下,我能够创建以下配置文件。几乎所有我都能找到的错误代码,我尝试使用proxy_next_upstream,但我仍然无法达到预期的结果。
我手动关闭主服务器以返回404.当它关闭时,它会短暂返回503。但是重定向流量仍然没有运气。 这两个服务器都作为nodejs应用程序托管在IBM Bluemix上。如果需要,我可以分享更多细节。
upstream up1 {
server up_server1;
}
upstream up2 {
server up_server2;
}
server {
listen 80;
location / {
proxy_pass http://up1;
proxy_next_upstream non_idempotent invalid_header error timeout http_500 http_502 http_504 http_403 http_404;
}
}
这由另一个看起来像的配置文件管理。只是为了提供更多信息
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log notice;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
# geoip_city /etc/nginx/geoip/GeoLiteCity.dat;
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
# TCP/UDP proxy and load balancing block
#
#stream {
# Example configuration for TCP load balancing
#upstream stream_backend {
# zone tcp_servers 64k;
# server backend1.example.com:12345;
# server backend2.example.com:12345;
#}
#server {
# listen 12345;
# status_zone tcp_server;
# proxy_pass stream_backend;
#}
#}
答案 0 :(得分:0)
您的问题是您不以任何方式使用upstream up2
。 proxy_next_upstream
表示当前上游的下一个服务器 - 定义为" up1"在proxy_pass http://up1
中,并没有神奇地挑选任何其他上游。
所以你想要的是删除upstream up2
而只留下:
upstream up1 {
server up_server1;
server up_server2;
}
答案 1 :(得分:-1)
我能够通过一个小小的调整来解决这个问题,几乎所有在堆栈溢出中发布的答案都错过了。当您使用proxy_next_upstream定义2个不同的上游时,需要将服务器添加为原始上游指令中的第二个条目。看看下面的代码。
upstream up1 {
server up_server1;
server up_server2; # this entry is important, but not sure why!
}
upstream up2 {
server up_server2;
}