一:安装realip模块
nginx -V看看有没有安装,没有就单独编译安装下,有就直接修改nginx的配置即可。
如果没有,就进nginx文件夹去编译: —with–http_realip_module
./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-http_gzip_static_module --with-ipv6 --with-http_sub_module --with-openssl=/root/lnmp1.4/src/openssl-1.0.2l --with-http_geoip_module --with-http_realip_module
#就是加上--with-http_realip_module
make && make install
kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`
kill -QUIT `cat /usr/local/nginx/logs/ nginx.pid.oldbin`
#改日志
然后nginx -V检测下有没有安装好。
二、修改nginx.conf配置文件
1:在http区域增加:
log_format main '$http_x_forwarded_for - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" ';
主要就是增加x-forwarded-for字段,如果没有上面这一段,就自己把这个复制进去也行。
2:在server区域增加:
set_real_ip_from CDNip1.0/24; #整个IP段
set_real_ip_from 源站ip;
set_real_ip_from 127.0.0.1; #服务器本地
real_ip_header X-Forwarded-For;
real_ip_recursive on;
set_real_ip_from获取ip地址,real_ip_header就是从header头检索ip,real_ip_recursive on获取ip,然后开始排除上面的ip,就显示出剩下的ip。
以上方法,有个不好的事情,就是CDNIP太多了,如果不能直接拿到,就得一次次的检测出ip来加上去。
还有一种方法:
log_format 域名 '$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/域名 域名; 日志
其实也算是通过http_x_forwarded_for来获取,只是读取的时候不一样。
因为后端真实服务器通过http_x_forwarded_for来获取,默认第一个不为unkown的ip就是访客的真实ip。
在server区域其实不用管了,默认配置的nginx.conf文件都有的。
第二种方法呢,就需要修改网站本身程序了,修改程序去读取第一个ip就行。
如果是不能修改网站本身程序,就还是用第一种方法吧。
三、测试访客ip
如果以上两种方法都用上了,可以写个php文件
<!--?php
echo $_SERVER['REMOTE_ADDR']; //通过读取real_ip_recursive来查看ip
echo "<br ?-->";
echo $_SERVER["HTTP_X_FORWARDED_FOR"]; //通过读取HTTP_X_FORWARDED_FOR来查看ip
?>
real_ip_recursive只会获取到当前的一个ip,HTTP_X_FORWARDED_FOR一般会读取到2个ip,第一个是真是ip,第二个是CDNip。
通过以上方法排除CDNip之后,我们就可以统计真实访客的ip了,当然也可以通过这个结合GeoIP模块屏蔽部分地区的ip访问网站。