CloudFlare CDN下Nginx正确获取真实IP教程
说到获取真实IP
,我们不难想到 nginx
的 http realip module
,就是当遇到IP
是设定范围内的地址时,就逆向递归获取源目标的真实IP
。对于Cloudflare CDN
而言,也是遵从行业标准的,即使用X-Forwarded-For header
和 CF-Connecting-IP header
。
Cloudflare
的真实IP地址可以从这里获取Cloudflare IP addresses
,当然我们也可以查看文本格式的Cloudflare
的IP
段:
https://www.cloudflare.com/ips-v4
https://www.cloudflare.com/ips-v6
找到了一个别人写好的sh
脚本,可以自动生成一个Cloudflare
真实IP
的conf
:
#!/bin/bash
echo "#Cloudflare" > /usr/local/nginx/conf/cloudflare_ip.conf;
for i in `curl https://www.cloudflare.com/ips-v4`; do
echo "set_real_ip_from $i;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
done
for i in `curl https://www.cloudflare.com/ips-v6`; do
echo "set_real_ip_from $i;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
done
echo "" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "# use any of the following two" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "real_ip_header CF-Connecting-IP;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "#real_ip_header X-Forwarded-For;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
运行脚本后,我们可以得到一个/usr/local/nginx/conf/cloudflare_ip.conf
的conf
文件,在网站所在的nginx conf
中添加字段:
include /usr/local/nginx/conf/cloudflare_ip.conf;
即可,添加完成后使用nginx –t
来验证配置文件是否正确,正确无误后重启或者重新载入nginx
即可。
也可以使用cron
计划任务来定期更新cloudflare_ip.conf
文件。
0 5 * * 1 /bin/bash /location/to/update_cf_ip.sh
这样子就可以在每周1
的5
点进行自动更新Cloudflare
的IP conf
文件了。如果使用配置文件中的X-Forwarded-For
参数,理论上对所有的执行标准的CDN
都是有效的。