the5fire的技术博客

关注python、vim、linux、web开发和互联网--life is short, we need python.


nginx误配proxy_add_x_forwarded_for导致网站挂掉 7876°C

作者:the5fire | 标签:     | 发布:2013-06-25 9:18 p.m.

刚才重新配置了下nginx,因为有些参数不太懂,因此导致了刚才网站一直打不开。查了好一会终于找到原因所在。

我在nginx的location配置中添加了一个:

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

$proxy_add_x_forwarded_for就等于客户端请求头中的"X-Forwarded-For",与$remote_addr用逗号分开。如果没有"X-Forwarded-For" 请求头,则$proxy_add_x_forwarded_for等于$remote_addr。$remote_addr变量的值是客户端的IP

而我读取头部的代码为:

if 'HTTP_X_FORWARDED_FOR' in request.META:
    ip = request.META['HTTP_X_FORWARDED_FOR']
else:
    ip = request.META['REMOTE_ADDR']

cache.set(ip, 0, 5 * 60)

如果在没有"X-Forwarded-For"头的情况下,获得到的ip就是单个的ip地址。但因为我自己配置的nginx上层还有一个nginx就只导致上层传过来的头中始终会有这个"X-Forwarded-For"头。因为 获取到的ip就是类似: '192.168.0.1, 127.0.0.1',这导致在调用memcached时key不合法。

参考:http://2hei.net/mt/2010/03/nginx-x-forwarded-for.html


----EOF-----

扫码关注,或者搜索微信公众号:the5fire

其他分类: