【Nginx】如何在 Nginx 中阻止来自特定国家的 IP 地址访问

embedded/2024/11/9 16:45:09/

文章目录

  • 前言
  • 一、准备工作
  • 二、查看 Nginx 服务器都拥有哪些模块
    • 2.1 先查看本地nginx是否有ngx_http_geoip2模块
    • 2.2 安装nginx并配置ngx_http_geoip2模块
      • 2.2.1下载所需版本的nginx到服务器
      • 2.2.2 先安装所需依赖
      • 2.2.3 解压文件
      • 2.2.4 下载ngx_http_geoip2模块
      • 2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录
      • 2.2.6 编译安装
    • 3.1 加载 IP 地理位置数据库
    • 3.2 配置拦截规则
    • 3.3 应用拦截规则
    • 3.4 重新加载 Nginx
  • 总结


前言

网络安全方面,有时你可能需要限制特定国家或地区的访问权限。本文将介绍如何使用 Nginx 配置文件来阻止来自特定国家或地区的 IP 地址访问你的网站。

一、准备工作

首先,确保你的 Nginx 服务器已经安装并正确配置ngx_http_geoip2 模块。另外,你需要获取一个 IP 地理位置数据库文件,通常是 GeoLite2 数据库,以便识别 IP 地址所属的国家或地区。具体步骤如下:

二、查看 Nginx 服务器都拥有哪些模块

nginxngx_http_geoip2_11">2.1 先查看本地nginx是否有ngx_http_geoip2模块

nginx -V

在这里插入图片描述
没有我们所需的模块,如果有的同学有该模块可以直接跳到下面直接配置nginx服务
在这里插入图片描述

在 Nginx 的配置文件中,添加以下代码以加载 IP 地理位置数据库文件:

nginxngx_http_geoip2_22">2.2 安装nginx并配置ngx_http_geoip2模块

本次使用的nginx是编译安装的方式,如果能找到本地的nginx编译的文件在哪就不用重新下载nginx,如果找不到请重新编译安装

nginx_24">2.2.1下载所需版本的nginx到服务器

下载地址

2.2.2 先安装所需依赖

yum install -y libmaxminddb-devel pcre-devel zlib-devel gcc gcc-c++ make git

2.2.3 解压文件

tar -xvzf nginx-1.24.0.tar.gz

2.2.4 下载ngx_http_geoip2模块

在服务上下载模块

git clone https://github.com/leev/ngx_http_geoip2_module.git

nginxngx_http_geoip2_module_44">2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录

切换到nginx所在目录

./configure --prefix=/nginxtest \--user=nginx \--group=nginx \--with-pcre \--with-http_ssl_module \--with-http_v2_module \--with-http_realip_module \--with-http_addition_module \--with-http_sub_module \--with-http_dav_module \--with-http_flv_module \--with-http_mp4_module \--with-http_gunzip_module \--with-http_gzip_static_module \--with-http_random_index_module \--with-http_secure_link_module \--with-http_stub_status_module \--with-http_auth_request_module \--with-http_image_filter_module \--with-http_slice_module \--with-mail \--with-threads \--with-file-aio \--with-stream \--with-mail_ssl_module \--with-stream_ssl_module \--add-module=/usr/local/ngx_http_geoip2_module

解释一下参数的含义
当你运行./configure时,你正在配置nginx的编译选项。以下是每行命令的解释:

–prefix=/nginxtest: 指定nginx的安装目录为/nginxtest,这意味着nginx将安装到该目录下。

–user=nginx: 指定nginx运行时的用户为nginx,这是为了增加安全性,以防止nginx以超级用户权限运行。

–group=nginx: 指定nginx运行时的用户组为nginx,与上述相似,也是为了增加安全性。

–with-pcre: 启用PCRE(Perl Compatible Regular Expressions)库,用于支持正则表达式。

–with-http_ssl_module: 启用HTTP SSL模块,支持HTTPS协议。

–with-http_v2_module: 启用HTTP/2模块,支持HTTP/2协议。

–with-http_realip_module: 启用HTTP RealIP模块,允许nginx在代理模式下获取真实的客户端IP地址。

–with-http_addition_module: 启用HTTP Addition模块,允许在响应中添加内容。

–with-http_sub_module: 启用HTTP Substitution模块,允许在响应中替换内容。

–with-http_dav_module: 启用HTTP DAV(WebDAV)模块,支持WebDAV协议。

–with-http_flv_module: 启用HTTP FLV模块,支持Flash视频流。

–with-http_mp4_module: 启用HTTP MP4模块,支持MP4视频流。

–with-http_gunzip_module: 启用HTTP GUNZIP模块,用于解压缩响应中的gzip压缩数据。

–with-http_gzip_static_module: 启用HTTP Gzip Static模块,用于在发送静态文件时压缩数据。

–with-http_random_index_module: 启用HTTP Random Index模块,允许nginx在目录中选择一个随机文件作为索引。

–with-http_secure_link_module: 启用HTTP Secure Link模块,用于生成带有安全签名的URL。

–with-http_stub_status_module: 启用HTTP Stub Status模块,允许监控nginx的状态信息。

–with-http_auth_request_module: 启用HTTP Auth Request模块,允许在需要认证时向另一个服务器发送认证请求。

–with-http_image_filter_module: 启用HTTP Image Filter模块,允许对图像进行处理。

–with-http_slice_module: 启用HTTP Slice模块,允许nginx按指定大小切片响应。

–with-mail: 启用邮件代理服务器功能。

–with-threads: 启用线程支持。

–with-file-aio: 启用文件异步IO支持。

–with-stream: 启用TCP/UDP流代理功能。

–with-mail_ssl_module: 启用邮件SSL模块,支持SSL加密的邮件传输。

–with-stream_ssl_module: 启用流SSL模块,支持SSL加密的TCP/UDP流。

--add-module=/usr/local/ngx_http_geoip2_module: 添加额外的模块ngx_http_geoip2_module,该模块用于GeoIP2地理定位功能。

2.2.6 编译安装

添加 nginx 模块,只需要编译,然后 make。不需要 make instll,不然线上的 nginx 会被新版本 nginx 完完整整的替换掉。完成后只需要覆盖替换就可以
在这里插入图片描述

make -j2 && make install #安装,重新安装的需要make install

结束查看一下是否安装成功

ln -s /nginxtest/nginx/sbin/nginx /usr/local/sbin/ #让系统识别nginx的操作命令
nginx- V

在这里插入图片描述
三、添加拦截规则配置

先下载 IP 地理位置数据库文件

3.1 加载 IP 地理位置数据库

nginx
http {# 加载 GeoIP 数据库文件geoip2 /path/to/GeoLite2-Country.mmdb { # 指定 GeoIP2 数据库文件路径auto_reload 60m; # 每 60 分钟自动重新加载数据库文件$geoip2_metadata_country_build metadata build_epoch; # 获取数据库元数据$geoip2_data_country_code country iso_code; # 获取 IP 所属国家的 ISO 代码}
}

3.2 配置拦截规则

在配置文件中添加拦截规则,指定你要阻止的国家或地区。以下是一个示例:

nginx
http {# 设置拦截规则map $geoip2_data_country_code $allowed_country {default yes; # 默认情况下允许访问CN no; # 指定中国 IP 地址不被拦截}
}

在这里插入图片描述

3.3 应用拦截规则

在你的服务器块或虚拟主机配置中,使用 if 指令结合上述定义的 map 指令来应用拦截规则:

nginx
server {listen 80;server_name example.com;if ($allowed_country = yes) { # 如果 IP 地址所属国家被标记为不允许访问return 403; # 返回 403 Forbidden 错误页面}# 其他配置项
}

3.4 重新加载 Nginx

完成配置后,重新加载或重启 Nginx 以使更改生效:

nginx -s reload

这样配置后,Nginx 将会拦截来自指定国家或地区的 IP 请求,并返回 403 Forbidden 错误页面。

在这里插入图片描述

总结

通过简单的 Nginx 配置,你可以有效地限制来自特定国家或地区的 IP 地址访问你的网站。这种措施有助于加强你的网络安全,保护你的服务器免受潜在的恶意攻击。


http://www.ppmy.cn/embedded/40879.html

相关文章

软件测试之如何管理团队

前言 在软件开发过程中,软件测试团队的管理至关重要。有效的团队管理可以提高测试质量、加快发布速度并确保产品的稳定性。本文将讨论如何管理软件测试团队,以便提供一些指导和最佳实践。 设定清晰的目标和期望 在管理软件测试团队时,首先…

SpringCloud面试题

SpringCloud常见组件有哪些 注册中心组件:Eureka、Nacos 负载均衡组件:Ribbon 远程调用组件:OpenFeign 网关组件:Zuul、Gateway 服务保护组件:Hystrix、Sentinel 服务配置管理组件:SpringCloudConfig、Nac…

可编程 IP 新星 Story Protocol 何以引领链上文艺复兴浪潮?

当前,随着 Web3 行业发展进入全新阶段,与生成式人工智能(AIGC)技术融合正在创造潜力新星项目。也是目前的互联网生态下,任何普通民众都有权利创作高质量的音乐、艺术、散文和视频内容,带来了用户生成内容&a…

【嵌入式开发 Linux 常用命令系列 7.6 -- sed 替换指定字符串】

请阅读【嵌入式开发学习必备专栏】 文章目录 sed 替换指定字符串 sed 替换指定字符串 背景: 找到当前目录下所有的.h 和 .c 文件 将他们中的字符 print_log替换为 demo_log 可以使用find命令结合sed命令在Linux环境下完成这项任务。下面是一个命令行示例&#xff…

房屋出租管理系统需求分析及功能介绍

房屋租赁管理系统适用于写字楼、办公楼、厂区、园区、商城、公寓等商办商业不动产的租赁管理及租赁营销;提供资产管理,合同管理,租赁管理, 物业管理,门禁管理等一体化的运营管理平台,提高项目方管理运营效率…

记录HCIP学习过程中的疑问

1、查看协议路由表、本地核心路由表、FIB表的命令??? 查看FIB表:display fib [ slot-id ] 2、最优路由选择,当达到目的地址的路由有多条时,本地核心路由 与FIB表的情况??&#xf…

学习前端第三十四天(call,apply,函数绑定;箭头函数;对象属性配置)

一、call、apply function fn(x, y) { console.log("hello", x, y, this) }; 1.call方法 作用:调用后执行函数,可以给“this”传参数 fn.call({ a: 1 }, 1, 2,); 2.apply方法 第一个给“this”传参数,第二个参数需要是数组形式…

MongoDB聚合运算符:$toHashedIndexKey

MongoDB聚合运算符:$toHashedIndexKey 文章目录 MongoDB聚合运算符:$toHashedIndexKey语法举例角度的双曲正切 $toHashedIndexKey计算并返回输入表达式的哈希值,其使用的哈希函数与MongoDB创建哈希索引相同。哈希函数将键值或字符串映射到固定…