使用了Cloudflare CDN后,网站获取到的IP地址都是Cloudflare的CDN节点的,不能得到真实用户的IP地址。好在Cloudflare已经为我们想到这一点了,将访问者的 IP 地址包含在 X-Forwarded-For 标头和 CF-Connecting-IP 标头。我们可以通过简单的脚本自动更新CDN节点。

使用Cloudflare后获取真实IP

官方IP地址

https://www.cloudflare.com/ips-v4

https://www.cloudflare.com/ips-v6

官方说明文档

https://support.cloudflare.com/hc/zh-cn/articles/200170786-%E6%81%A2%E5%A4%8D%E5%8E%9F%E5%A7%8B%E8%AE%BF%E9%97%AE%E8%80%85-IP-%E4%BD%BF%E7%94%A8-mod-cloudflare-%E8%AE%B0%E5%BD%95%E8%AE%BF%E9%97%AE%E8%80%85-IP-%E5%9C%B0%E5%9D%80-

需要Nginx有http_realip_module模块

获取真实IP

set_real_ip_from 0.0.0.0/0;
#set_real_ip_from ::/0; 如果需要IPV6
real_ip_header  X-Forwarded-For;
#real_ip_header CF-Connecting-IP; cloudlfare可以用这个
real_ip_recursive on;

添加到nginx.conf的http块里面

  • set_real_ip_from:定义接受从哪个信任前代理处获得真实用户ip,可以定义多行,可定义为ip,ip段,支持ipv4和ipv6
  • real_ip_header:定义从接收到报文的哪个http头部去获取前代理传送的用户ip,默认为X-Real-IP
  • real_ip_recursive:递归搜索,默认为off

传递真实IP

proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

添加到nginx.conf的http块里面

自动获取Cloudflare的真实IP并自动更新IP段

生成配置文件脚本

#!/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;

引入配置文件

include /usr/local/nginx/conf/cloudflare_ip.conf;

计划任务

0 5 * * 1 /bin/bash /usr/local/nginx/conf/update_cf_ip.sh

配合vddos

#!/bin/bash
echo "#Cloudflare" > /vddos/conf.d/cdn-ip.conf;
for i in `curl https://www.cloudflare.com/ips-v4`; do
        echo "set_real_ip_from $i;" >> /vddos/conf.d/cdn-ip.conf;
done
for i in `curl https://www.cloudflare.com/ips-v6`; do
        echo "set_real_ip_from $i;" >> /vddos/conf.d/cdn-ip.conf;
done
echo "" >> /vddos/conf.d/cdn-ip.conf;
echo "real_ip_header X-Forwarded-For;" >> /vddos/conf.d/cdn-ip.conf;
echo "real_ip_recursive on;" >> /vddos/conf.d/cdn-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 /usr/local/nginx/conf/update_cf_ip.sh

这样子就可以在每周1的5点进行自动更新Cloudflare的IP conf文件了。如果使用配置文件中的X-Forwarded-For参数,理论上对所有的执行标准的CDN都是有效的。

参考文档

https://wzfou.com/cdn-real-ip/

文章目录