Nginx反向代理Tomcat日志获取真实IP

2021/4/17 7:27:12

本文主要是介绍Nginx反向代理Tomcat日志获取真实IP,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

Nginx作为反向代理时,Tomcat的日志记录的客户端IP就不在是真实的客户端IP,而是Nginx代理的IP。要解决这个问题可以在Nginx配置一个新的Header,用来存储$remote_addr,然后再Tomcat获取记录这个值。

Nginx 配置文件,加入这行

proxy_set_header  X-Forwarded-For $remote_addr;

可以参见:http://wiki.nginx.org/NginxHttpProxyModule

其实就是新增了一个名为X-Real-IP值为真实客户端IP的头信息。

 

Tomcat 的 server.xml, 做如下修改: 

         <Valve className="org.apache.catalina.valves.RemoteIpValve"   
                       remoteIpHeader="x-forwarded-for"
                       remoteIpProxiesHeader="x-forwarded-by" />
                       
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%{X-Real-IP}i %a %t %r %s %b" resolveHosts="false" />

 

 

没有Nginx这一层的时候直接用%a就可以获得客户端IP,现在我们得用%{X-Real-IP}i 来获得真实的IP了。

之后重启Nginx,Tomcat就可以了

 

 



这篇关于Nginx反向代理Tomcat日志获取真实IP的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程