让后端tomcat日志获取真实的IP,而不是nginx 服务器的IP

本文介绍如何在Nginx和Tomcat中配置代理头信息和访问日志,通过设置Nginx的proxy_set_header来传递客户端真实IP,并在Tomcat中配置AccessLogValve以记录包含X-Forwarded-For字段的日志。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nginx nginx.conf中加
proxy_set_header X-Forwarded-For $remote_addr;
tomcat server.xml中加
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log." suffix=".txt"
pattern="%{X-FORWARDED-FOR}i %l %u %t %r %s %b %D %q %{User-Agent}i %T" resolveHosts="false"/>
nginxtomcat一起使用时,通常的工作流程如下: 1. 客户端向nginx发送请求。 2. nginx根据配置将请求转发给tomcat服务器。 3. tomcat服务器处理请求并返回响应。 4. nginx将响应返回给客户端。 在这个过程中,nginx可以作为反向代理服务器,负责接收客户端请求并将其转发给tomcat服务器。同时,nginx还可以对请求进行一些处理,例如负载均衡、缓存、SSL加密等。而tomcat服务器则负责处理请求并返回响应,通常用于运行Java Web应用程序。 如果需要让后端web服务器(如tomcat获取客户端真实IP地址,而不是nginx代理服务器IP地址,可以通过在nginx配置文件中添加以下代码来实现: ``` proxy_set_header X-Forwarded-For $remote_addr; ``` 这样,nginx会将客户端的真实IP地址添加到请求头中,然后将请求转发给tomcat服务器。在tomcat服务器中,可以通过读取请求头中的X-Forwarded-For字段来获取客户端的真实IP地址。 如果需要查看tomcat服务器的访问日志,可以通过在tomcat的配置文件中添加以下代码来实现: ``` <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> ``` 这样,tomcat服务器会将访问日志保存在logs目录下,文件名为localhost_access_log.<日期>.txt。可以使用以下命令来实时查看日志: ``` tail -0f /usr/local/tomcat/logs/localhost_access_log.<日期>.txt ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值