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

文章目录

  • 前言
  • 一、准备工作
  • 二、查看 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 服务器都拥有哪些模块

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

nginx -V

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

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

2.2 安装nginx并配置ngx_http_geoip2模块

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

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

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 地址访问你的网站。这种措施有助于加强你的网络安全,保护你的服务器免受潜在的恶意攻击。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/626263.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决webstorm没有vue语法提示;webstorm没有代码提示

解决webstorm没有vue语法提示;webstorm没有代码提示 使用webstorm 2023.x 开发vue项目。发现死活没有vue语法提示,即便是npm install、清理缓存。对比其他vue项目却有语法提示,最后发现依赖库被忽略了: 删除掉node_modules 的忽略…

国外IP代理免费试用技巧

随着互联网的普及,人们越来越依赖于网络来获取信息、进行交流和娱乐。国外IP代理就成了利器之一。在本文中,我们将探讨如何免费使用国外IP代理。 一、了解国外IP代理的原理 国外IP代理,简单来说,就是通过连接到位于国外的代理服务…

linux 环境下 分布式文件搭建fastDFS

1.软件信息 地址:happyfish100 (YuQing) GitHub 1.fastdfs-master.zip 2.fastdfs-nginx-module-master.zip 3.libfastcommon-master.zip 4.libserverframe-master.zip yum install make cmake gcc gcc-c perl 2.安装libfastcommon unzip libfastcommon-mast…

怎么转换音频?看这3款音频转换器

随着数字媒体的发展,音频文件在我们的日常生活中占据了越来越重要的地位。有时候在不同的应用场景里,无论是音乐、语音还是其他类型的音频内容,我们都需要对其进行转换以满足不同的需求。 本文将为您介绍3款常用的音频转换器,帮助…

代码随想录训练营Day31:动态规划3:0-1背包

1.0-1背包基础 有n件物品和一个最多能背重量为w 的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品只能用一次,求解将哪些物品装入背包里物品价值总和最大。 1.1动态规划五部曲 确定dp数组以及下标的含义:dp[i][j] 表示…

sql操作、发送http请求和邮件发送 全栈开发之路——后端篇(2)

全栈开发一条龙——前端篇 第一篇:框架确定、ide设置与项目创建 第二篇:介绍项目文件意义、组件结构与导入以及setup的引入。 第三篇:setup语法,设置响应式数据。 第四篇:数据绑定、计算属性和watch监视 第五篇 : 组件…

RK3566(泰山派):3.1寸屏幕D310T9362V1SPEC触摸驱动(竖屏)

RK3566(泰山派):3.1寸屏幕D310T9362V1SPEC触摸驱动(竖屏) 文章目录 RK3566(泰山派):3.1寸屏幕D310T9362V1SPEC触摸驱动(竖屏)电路配置i2c1设备树创建驱动编写…

什么是50etf期权?期权的三级交易权限是什么?

今天期权懂带你了解什么是50etf期权?期权的三级交易权限是什么?期权三级交易权限,作为股票期权交易中的最高级别权限,赋予了投资者更广泛、更灵活的交易选择和策略。 什么是50etf期权? ETF期权是指在支付一定额度的权…

如何让机器理解人类语言?Embedding技术详解

如何让机器理解人类语言?Embedding技术详解 文章目录 如何让机器理解人类语言?Embedding技术详解介绍什么是词嵌入?什么是句子嵌入?句子嵌入模型实现句子嵌入的方法值得尝试的句子嵌入模型 句子嵌入库实践Step 1Step 2Step 3 Doc2…

SwiftUI中三大渐变色的介绍

在SwiftUI中,渐变色是一种常用的视觉效果,用于创建平滑过渡的颜色变化。通过使用渐变色,我们可以实现丰富多彩的界面设计,增强用户体验。 1. 渐变色的种类和用途 种类: 线性渐变(Linear Gradient&#x…

oracle多条重复数据,取最新的

1、原理讲解-可直接看2 筛选出最新的 SELECT * FROM ( SELECT t.*, ROW_NUMBER() OVER (PARTITION BY LOCALAUTHID ORDER BY LASTUPDATETIME DESC) AS rn FROM USER_LOCALAUTH_STATE t ) t WHERE t.rn 1; 解释: 这个序号是基于[LOCALAUTHID]字段进行分…

计算机vcruntime140.dll找不到如何修复,分享5种靠谱的修复教程

当您在运行某个应用程序或游戏时遇到提示“找不到vcruntime140.dll”,这通常意味着系统中缺少了Visual C Redistributable for Visual Studio 2015或更高版本的一个重要组件。这个错误通常发生在运行某些程序时,系统无法找到所需的动态链接库文件。小编将…

ASP.NET医药进销存系统

摘 要 目前,大中型城市的多数药品店已经实现了商品管理、客户管理、销售管理及销售管理等的信息化和网络化,提高了管理效率。但是,在大多数小药品店,药品店管理仍然以传统人工管理为主,特别是在药品的采购、销售、库…

电商核心技术揭秘56:客户关系管理与忠诚度提升

相关系列文章 电商技术揭秘相关系列文章合集(1) 电商技术揭秘相关系列文章合集(2) 电商技术揭秘相关系列文章合集(3) 文章目录 引言客户关系管理(CRM)的重要性提升顾客体验数据驱…

Springboot打包jar如何后台启动和查看日志?

如何后台启动Spring Boot的fat jar 使用nohup命令启动: 在Linux或Unix系统中,你可以使用nohup命令来启动jar包,以确保即使你关闭了终端或断开了SSH连接,程序仍然可以在后台运行。命令格式如下:nohup java -jar yourapp…

PCie协议之-TLP Header详解(一)

✨前言: 在PCIe通信过程中,事务层数据包(Transaction Layer Packets,简称TLP)扮演着非常重要的角色。TLP用于在设备之间传递数据和控制信息,它们是PCIe的基本信息传输单元。 TLP可分为几个部分&#xff0c…

硬盘格式化后能恢复数据吗?这个恢复方法电脑小白也能用!

硬盘格式化后能恢复数据吗?对于这个问题需要先了解清楚硬盘格式化和数据恢复的原理了。 目前我们所说的硬盘格式化通常都是指“快速格式化”,一般来说当我们在清理磁盘空间或者新建磁盘分区时会使用到这个功能,最终的结果就是清除掉磁盘上的…

“打工搬砖记”中吃什么的轮盘功能实现(二)

文章目录 打工搬砖记转盘主要的逻辑实现转盘的素材小结 打工搬砖记 先来一个吃什么轮盘的预览图,这轮盘文案加字呈圆形铺出来,开始后旋转到指定的选项处停下来。 已上线小程序“打工人搬砖记”,可以扫码进行预览观看。 转盘主要的逻辑实现…

【Unity Shader入门精要 第7章】基础纹理补充内容:MipMap原理

1.纹理采样 我们对纹理采样进行显示的过程,可以理解为将屏幕上的一个像素(下文用像素表示)映射到纹理上的一个像素(下文用纹素表示),然后用纹理上的这个像素的颜色进行显示。 理想情况下,屏幕…

AcqKnowledge 5.0使用方法

Biopac 数据导入 matlab 处理方法 第一步:在 AcqKnowledge 软件中,将数据通道的 mark 信息导入到 Graph,并将数据存储为 acq3 的格式 第二步:MATLAB中读取acq3文件脚本 clc clear %%%所有被试这一层路径 pathsub fullfile(file…