在使用Nginx做反向代理后, tomcat的访问日志ip地址始终为127.0.0.1, 是nginx反向代理的地址, 需要访问日志为实际ip地址, 修改tomcat/conf/server.xml文件.
默认如下:
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" pattern="%h %l %u %t "%r" %s %b" prefix="localhost_access_log" suffix=".txt"/>
pattern可以自定义, 具体参照docs/config/valve.html
获取实际地址还要添加另一个valve, 这里nginx.conf中设置了header, (proxy_set_header X-Real-IP $remote_addr;)
header头部的key为X-Real-IP, 所以这里remoteIpHeader取该值即可, 默认是取x-forward-for.
<Valve className="org.apache.catalina.valves.RemoteIpValve" remoteIpHeader="X-Real-IP" />
将上面这个配置加入到server.xml中, 默认的AccessLogValve上面就可以了.
除此之外, 修改默认Valve的pattern, 将pattern的%h 替换为 %{X-Real-IP}i, %h是代表请求主机, 改成实际ip参数, 注意i代表发来请求的header中的参数, %{X-Real-IP}i代表从请求头中取参数X-Real-IP参数.
重启访问就可以获取到实际ip地址了