Resin在加了Nginx负载均衡后Resin访问日志中得到的ip为Nginx的ip,不是客户端的真实ip,需要修改resin的配置文件cluster-default.xml(resin 4):
1. 修改配置Nginx
在Nginx配置添加一个新的Header,用来存储$remote_add,然后再Resin获取记录这个值。
Nginx:
server {
listen 80;
server_name www.xxxxx.com;
location / {
proxy_pass http://IP:81/;
proxy_set_header X-Real-IP $remote_addr;
}
}
添加一个为X-Real-IP值为真实IP的header 信息。
2. Resin配置
Resin配置文件cluster-default.xml中找到 <access-log> , 替换为如下信息:
<access-log path="log/access.log"
format='"%{X-Real-IP}i" %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i"'
rollover-period="1W"/>
3. 重启nginx和Resin服务,access.log 日志中,就可以看到真实的客户端IP了。
这里面参考了,官方文档 http://www.caucho.com/resin-4.0/admin/logging.xtp 里面的 format patterns 设置。