nginx plus与proxy_next_upstream指令不起作用

时间:2017-03-23 16:21:57

标签: nginx ibm-cloud load-balancing failover

问题陈述: 我想使用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;
    #}
#}

2 个答案:

答案 0 :(得分:0)

您的问题是您不以任何方式使用upstream up2proxy_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;

}