ruby-on-rails – 当从私有NIC访问时,Rails显示IP为127.0.0.1,
发布时间:2020-12-13 21:24:24 所属栏目:Nginx 来源:网络整理
导读:我们正在Unicorn Nginx上运行Rails应用程序.服务器有两个我们使用的网卡. eth0处理公共互联网的请求,eth2处理来自我们私人网络的请求. 当通过eth0发出请求时,nginx日志显示公网IP,而Rails日志也显示此IP.但是,当通过eth2发出请求时,nginx日志会显示私有IP(例
我们正在Unicorn Nginx上运行Rails应用程序.服务器有两个我们使用的网卡. eth0处理公共互联网的请求,eth2处理来自我们私人网络的请求. 当通过eth0发出请求时,nginx日志显示公网IP,而Rails日志也显示此IP.但是,当通过eth2发出请求时,nginx日志会显示私有IP(例如192.168.5.134),但是Rails日志显示为127.0.0.1. 所以似乎eth0上的公共请求让他们的X-Forwarded-For头设置正确,但是这并不是针对eth2的请求发生的. 我们的nginx配置是非常基本的:
有任何想法吗? 最佳答案
问题是Rails认为任何192.168.x.x地址是一个私有地址,因此从X-Forwarded_For标题中删除它们.
请参阅相关的Rails源here和here. 一个解决方案是将其添加到你的config / application.rb中:
这样,本地网络上的IP将不会被’127.0.0.1’所取代. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- Nginx返回一个假的200状态代码的空json对象
- ubuntu – PHP启动:无法加载动态库(NEW RELIC)
- 深入分析Nginx 502 Bad Gateway和Nginx 504 Gateway
- nginx-部分加载的javascript文件
- apache-2.2 – 在NginX后面的Apache mod_dav安装上,WebDav
- nginx – ELB和服务器上的SSL
- 使用opsworks nginx和ELB终止SSL时强制使用HTTPS
- svn – 使用NGINX在Ubuntu上安装Subversion,而不是Apache
- Ubuntu 14.04中缺少nginx php5-fpm conf文件
- nginx – 4000个请求中有1个出现HTTP 499错误是否正常?