外贸站点启用CDN,如何通过Nginx获取访客真实IP教程

网站启用 CDN 后 Nginx 日志里的访客 IP 会变成 CDN 的,需要借助 http_realip_module 这个模块,通过 HTTP 标头里的 X_FORWARDED_FOR 字段获取访客真实 IP。本文主要介绍使用腾讯云CDN后如何获取Nginx服务的真实IP地址,以下是具体配置方法。

Nginx服务使用阿里云CDN后,用户访问的IP地址不真实,怎样获取真实的IP地址。在Nginx服务的配置文件内location配置项添加如下内容,就可以获取到Nginx服务的真实IP地址。

检查 http_realip_module 是否已安装

nginx -V 2>&1 | tr ' ' '/n' | grep 'http_realip_module'

如果有输出结果就表示已安装。通常这个模块作为内置模块安装。

创建 CDN IP 列表配置文件

手动创建方法

vi /etc/nginx/conf.d/http_realip.conf

内容如下。

set_real_ip_from  173.245.48.0/20;
...
set_real_ip_from  2400:cb00::/32;
real_ip_header    X-Forwarded-For;
real_ip_recursive on;

参数说明:

  • set_real_ip_from :可信 CDN 来源 IP。如果有多个,则多行添加;
  • real_ip_header :带有访客 IP 信息的 Header 字段名称;
  • real_ip_recursive :排除已配置的 CDN IP(即其它 IP 认为访客 IP);

编辑 /etc/nginx/nginx.conf 配置文件,在 http{...} 中加入引用参数。

注:通过 DNF 或 YUM 安装的 Nginx,可跳过这个步骤,因为 Nginx 配置文件已设置默认引用 /etc/nginx/conf.d 目录下的 *.conf 文件。


include /etc/nginx/conf.d/http_realip.conf;

之后刷新 Nginx 服务生效。

nginx -s reload

自动创建方法

为避免 CDN IP 变化后需要手动更新的麻烦,可以使用 Shell 脚本自动生成配置文件,并设置定时更新。

1. 创建 Shell 脚本

vi /etc/nginx/conf.d/http_realip.sh

2. Shell 脚本内容(CloudFlare 版)

#!/usr/bin/env bash

echo "# Restoring original visitor IPs" > /etc/nginx/conf.d/http_realip.conf;
for i in `curl https://www.cloudflare.com/ips-v4`; do
    echo "set_real_ip_from  $i;" >> /etc/nginx/conf.d/http_realip.conf;
done
for i in `curl https://www.cloudflare.com/ips-v6`; do
    echo "set_real_ip_from  $i;" >> /etc/nginx/conf.d/http_realip.conf;
done
echo "real_ip_header    X-Forwarded-For;" >> /etc/nginx/conf.d/http_realip.conf;
echo "real_ip_recursive on;" >> /etc/nginx/conf.d/http_realip.conf;
nginx -s reload

3. 赋予可执行权限

chmod +x /etc/nginx/conf.d/http_realip.sh

4. 使用 crontab -e 命令添加定时任务,内容如下(每月 1 号凌晨 5 点 30 运行更新)

30 5 1 * * /etc/nginx/conf.d/http_realip.sh 2>&1 > /dev/null

5. 编辑 /etc/nginx/nginx.conf 配置文件,在 http{...} 中加入引用参数。

注:通过 DNF 或 YUM 安装的 Nginx,可跳过这个步骤,因为 Nginx 配置文件已设置默认引用 /etc/nginx/conf.d 目录下的 *.conf 文件。


include /etc/nginx/conf.d/http_realip.conf;

6. 手动运行一次脚本,以生成配置文件,并刷新 Nginx 服务生效。

/etc/nginx/conf.d/http_realip.sh

刷新网站检查访客 IP 是否获取正常

刷新网站,查看访问日志里的 IP 是否是访客 IP(具体日志文件路径见站点配置文件)。

tail /var/www/log/example.com.access.log

相关文章

Nginx部署Vue项目以及解决刷新页面404

在部署vue、react的前端项目时,经常会出现404的问题,一般是文件不是真正的存在,所以Nginx报404的错误一、打包项目 1.在项目中的package.json上右键,点击Show npm...

Nginx合集-移动端&PC端自动跳转

效果使用浏览器访问https://www.jd.com/就进入了jd的pc端页面把浏览器切换为手机模式刷新一下页面,就会发现自动进入了https://m.jd.com/nginx配置假设PC端域名为...

Nginx实战-监控nginx.conf配置文件,配置文件修改自动重启nginx

1.1 实现目标在学习或者进行nginx测试的时候,耗费在 nginx -s reload/stop 上的命令时间很多,修改任意内容都需要重新启动或者停止启动,基本上状态就是在下面5个状态间来回切换v...

初学者必须掌握的nginx常用命令

1、检查配置文件(nginx.conf) nginx -t2、启动nginx -c /usr/local/nginx/conf/nginx.conf3、停用nginx -s stop4、刷新配置文件(...

网站安全提速秘籍!Nginx配置HTTPS+反向代理实战指南

太好了,你直接问到重点场景了:Nginx + HTTPS + 反向代理,这个组合是现代 Web 架构中最常见的一种部署方式。咱们就从理论原理 → 实操配置 → 常见问题排查 → 高级玩法一层层剖开说,...

一文带你详解Nginx/OpenResty,Nginx Lua编程基础,学不会别怪我

Nginx Lua编程基础OpenResty通过汇聚各种设计精良的Nginx模块(主要由OpenResty团队自主开发)将Nginx变成一个强大的通用Web应用平台。这样,Web开发人员和系统工程师可...