文章目录
- 前言
- 一、准备工作
- [二、查看 Nginx 服务器都拥有哪些模块](#二、查看 Nginx 服务器都拥有哪些模块)
-
- [2.1 先查看本地nginx是否有ngx_http_geoip2模块](#2.1 先查看本地nginx是否有ngx_http_geoip2模块)
- [2.2 安装nginx并配置ngx_http_geoip2模块](#2.2 安装nginx并配置ngx_http_geoip2模块)
-
- 2.2.1下载所需版本的nginx到服务器
- [2.2.2 先安装所需依赖](#2.2.2 先安装所需依赖)
- [2.2.3 解压文件](#2.2.3 解压文件)
- [2.2.4 下载ngx_http_geoip2模块](#2.2.4 下载ngx_http_geoip2模块)
- [2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录](#2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录)
- [2.2.6 编译安装](#2.2.6 编译安装)
- [3.1 加载 IP 地理位置数据库](#3.1 加载 IP 地理位置数据库)
- [3.2 配置拦截规则](#3.2 配置拦截规则)
- [3.3 应用拦截规则](#3.3 应用拦截规则)
- [3.4 重新加载 Nginx](#3.4 重新加载 Nginx)
- 总结
前言
在网络安全方面,有时你可能需要限制特定国家或地区的访问权限。本文将介绍如何使用 Nginx 配置文件来阻止来自特定国家或地区的 IP 地址访问你的网站。
一、准备工作
首先,确保你的 Nginx 服务器已经安装并正确配置ngx_http_geoip2 模块。另外,你需要获取一个 IP 地理位置数据库文件,通常是 GeoLite2 数据库,以便识别 IP 地址所属的国家或地区。具体步骤如下:
二、查看 Nginx 服务器都拥有哪些模块
2.1 先查看本地nginx是否有ngx_http_geoip2模块
go
nginx -V
没有我们所需的模块,如果有的同学有该模块可以直接跳到下面直接配置nginx服务
在 Nginx 的配置文件中,添加以下代码以加载 IP 地理位置数据库文件:
2.2 安装nginx并配置ngx_http_geoip2模块
本次使用的nginx是编译安装的方式,如果能找到本地的nginx编译的文件在哪就不用重新下载nginx,如果找不到请重新编译安装
2.2.1下载所需版本的nginx到服务器
2.2.2 先安装所需依赖
go
yum install -y libmaxminddb-devel pcre-devel zlib-devel gcc gcc-c++ make git
2.2.3 解压文件
go
tar -xvzf nginx-1.24.0.tar.gz
2.2.4 下载ngx_http_geoip2模块
在服务上下载模块
go
git clone https://github.com/leev/ngx_http_geoip2_module.git
2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录
切换到nginx所在目录
go
./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 完完整整的替换掉。完成后只需要覆盖替换就可以
go
make -j2 && make install #安装,重新安装的需要make install
结束查看一下是否安装成功
go
ln -s /nginxtest/nginx/sbin/nginx /usr/local/sbin/ #让系统识别nginx的操作命令
nginx- V
三、添加拦截规则配置
先下载 IP 地理位置数据库文件
3.1 加载 IP 地理位置数据库
go
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 配置拦截规则
在配置文件中添加拦截规则,指定你要阻止的国家或地区。以下是一个示例:
go
nginx
http {
# 设置拦截规则
map $geoip2_data_country_code $allowed_country {
default yes; # 默认情况下允许访问
CN no; # 指定中国 IP 地址不被拦截
}
}
3.3 应用拦截规则
在你的服务器块或虚拟主机配置中,使用 if 指令结合上述定义的 map 指令来应用拦截规则:
go
nginx
server {
listen 80;
server_name example.com;
if ($allowed_country = yes) { # 如果 IP 地址所属国家被标记为不允许访问
return 403; # 返回 403 Forbidden 错误页面
}
# 其他配置项
}
3.4 重新加载 Nginx
完成配置后,重新加载或重启 Nginx 以使更改生效:
go
nginx -s reload
这样配置后,Nginx 将会拦截来自指定国家或地区的 IP 请求,并返回 403 Forbidden 错误页面。
总结
通过简单的 Nginx 配置,你可以有效地限制来自特定国家或地区的 IP 地址访问你的网站。这种措施有助于加强你的网络安全,保护你的服务器免受潜在的恶意攻击。