当前位置:首页 > 技术文章 > 正文内容

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

arlanguage3个月前 (01-20)技术文章24

网站启用 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

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/962.html

标签: 腾讯 nginx
分享给朋友:

“外贸站点启用CDN,如何通过Nginx获取访客真实IP教程” 的相关文章

2020全网最全的Nginx 性能调优实战

1、Nginx运行工作进程数量Nginx运行工作进程个数一般设置CPU的核心或者核心数x2。如果不了解cpu的核数,可以top命令之后按1看出来,也可以查看/proc/cpuinfo文件 grep ^processor /proc/cpuinfo | wc -l[root@lx~]# vi/usr/...

三年前端还不会配置Nginx?刷完这篇就够了

一口气看完,比自学强十倍!什么是NginxNginx是一个开源的高性能HTTP和反向代理服务器。它可以用于处理静态资源、负载均衡、反向代理和缓存等任务。Nginx被广泛用于构建高可用性、高性能的Web应用程序和网站。它具有低内存消耗、高并发能力和良好的稳定性,因此在互联网领域非常受欢迎。为什么使用N...

Nginx热升级流程,看这篇就够了

在之前做过 Nginx 热升级的演示,他能保证nginx在不停止服务的情况下更换他的 binary 文件,这个功能非常有用,但我们在执行 Nginx 的 binary 文件升级过程中,还是会遇到很多问题,比如老的 worker 进程一直退不掉或者新的 worker 进程升级以后出现问题需要考虑回滚,...

一文教会你如何使用 iLogtail SPL 处理日志

作者:阿柄随着流式处理的发展,出现了越来越多的工具和语言,使得数据处理变得更加高效、灵活和易用。在此背景下,SLS 推出了 SPL(SLS Processing Language) 语法,以此统一查询、端上处理、数据加工等的语法,保证了数据处理的灵活性。iLogtail 作为日志、时序数据采集器,在...

Wordpress+Nginx代理部署实战

一、文档说明本文档主要介绍wordpress+nginx架构调整。Wordpress默认的前端架构是httpd,为了便于管理和拓展需求,现替换为nginx作为前端代理,并使其实现前后端分离。二、建设背景一般情况我们架设wordpress 的结构是这样的:客户端直接访问Wordpress服务器,这种形...

配置Nginx TCP转发

Nginx一般用在HTTP的转发,TCP的转发大都会使用HAProxy。工作中遇到一个需求,用到了Nginx服务作为TCP转发。场景是这样,数据采集设备通过公网将数据推送到后端应用服务,服务部署在业主的IDC中,不能对外暴露,有现成的Nginx服务器部署在DMZ中,充当数据转发服务,拓扑如下:网络拓...