如何让varnish做反向代理的后端服务器显示真实用户IP

本文介绍如何通过X-Forwarded-For头信息在使用反向代理时获取客户端的真实IP地址。当请求经过反向代理服务器时,原始客户端IP会丢失,X-Forwarded-For提供了解决方案。文章详细解释了如何在Apache和Varnish中配置这一头部,以确保后端服务器能够正确记录客户端IP。

当我们使用反向代理程序时后端服务器的程序经常需要获得客户端的IP地址,从而做一些针对用户的程序操作,如根据IP地址在页面中显示不同的语言等。。但如果加入了反响代理的话,后端服务器看到的连接都是反向代理所发起的,而不是真实用的IP地址。出于这种需求 X-Forwarded-For 头孕育而生了。这个HTTP头信息是反向代理程序加入的。Varnish原生支持X-Forwarded-For头信息。关于X-Forwarded-For更多信息参见:http://en.wikipedia.org/wiki/X-Forwarded-For

Varnish 2.04 版本中默认已经加入了X-Forwarded-For头信息。如果后端服务器想在日志文件中查看到真实的用户IP可以修改配置文件来实现:

apache 

LogFormat "%{X-Forwarded-For}i %l %u %t /"%r/" %>s %b /"%{Referer}i/" /"%{User-Agent}i/"" varnishcombined
 
CustomLog /var/log/apache2/www.example.com/access.log varnishcombined

这样在apache的日志文件中就可以看到客户端真实的IP地址了。如果无法显示,则需要修改Varnish的配置文件

 
sub vcl_recv {
# Add a unique header containing the client address
remove req.http.X-Forwarded-For;
set req.http.X-Forwarded-For = client.ip;
}

我这里测试的情况是如果我添加上面的两行,apache的日志就会输出两个客户端的ip地址。因此我没添加这两行。

nginx

?[Copy to clipboard] View Code BASH
1
2
3
4
log_format  access  '$remote_addr - $remote_user [$time_local] "$request" '
 '$status $body_bytes_sent "$http_referer" '
 '"$http_user_agent" $http_x_forwarded_for';
 access_log      /usr/local/nginx/logs/access.log  access;
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值