【Nginx】Nginx反向代理转发Host设置
#事故现场:
服务器A(Nginx服务器):192.168.2.126
服务器B(Web服务器):192.168.2.221
服务器A反向代理服务器B,A配置了upstream为:
http {
upstream test_server {
server 192.168.2.221:8080 weight=1 max_fails=3 fail_timeout=30s;
}
}
用浏览器访问A:192.168.2.126 在服务端获取Host,结果为:test_server ,而我想得到的是:192.168.2.221
context.Request.Headers.Get("Host");// text_server context.Request.ServerVariables["SERVER_NAME"]; // text_server
#原因及解决方案:
默认情况下反向代理是不会转发请求中的Host头部,如果需要转发,则需要配置红色字体表示的选项参数。
location /test {
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_pass http://192.168.2.12:5252/test;
}
#如果不修改Nginx配置,那服务端代码如何获取原始Host呢?
以asp.net代码为例:
HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_HOST"];
#参考:https://www.cnblogs.com/yshyee/p/7531264.html
___________________________________________________________________________________________
作者:willingtolove
出处:http://www.cnblogs.com/willingtolove/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。