当前位置: 首页 > news >正文

nginx的docker镜像封禁地区IP

一、拉取镜像

此镜像的Nginx 已经集成了ngx_http_geoip2_module模块。

docker pull anroe/nginx-geoip2:1.22.1-geoip2-3.4

二、nginx.conf配置文件

1.加载geoip2模块。

load_module /usr/lib/nginx/modules/ngx_http_geoip2_module.so;

如下图所示:

2.http模块中获取客户端真实ip地址:

map $http_x_forwarded_for $clientRealIp { "" $remote_addr; ~^(?P<firstAddr>[0-9\.]+),?.*$ $firstAddr; }

如下图:

3.从 github或者maxmind下载GeoLite2-City.mmdb文件。使 Nginx 结合 GeoLite2 数据库来获取地理位置。

GeoLite2-City.mmdb 是 MaxMind 提供的免费 IP 地理位置数据库。

存在位置漂移与精度低,数据信息缺失:对于某些 IP 地址,尤其是手机移动网络的 IP 或非热门地区的 IP,可能无法解析出具体的城市信息,甚至国家信息也可能缺失。

geoip2 /etc/nginx/GeoLite2-City.mmdb { auto_reload 5m; $geoip2_city_name_en source=$clientRealIp city names en; $geoip2_city_name_cn source=$clientRealIp city names zh-CN; }

新建目录:

mkdir -p /home/app/geoip

下载好文件后至该服务器目录下。

4.添加响应头方便排查问题

add_header X-City-Code $geoip2_city_name_en always;

5.server模块判断ip区域

if ($geoip2_city_name_en ~* "(Guangzhou)") { return 403; }

如下图所示:

三.启动nginx 容器

docker run --name nginx-geoip2 -p 443:443 -d -v /usr/local/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /home/app/geoip/GeoLite2-City.mmdb:/etc/nginx/GeoLite2-City.mmdb --restart=always anroe/nginx-geoip2:1.22.1-geoip2-3.4

-v /home/app/geoip/GeoLite2-City.mmdb:/etc/nginx/GeoLite2-City.mmdb

将geoip文件映射到容器中,配置文件能引用到:

四、测试

命令: 61.146.4.192替换为客户的ip地址。可以获取到ip所属区域。

curl -s -I --header "X-Forwarded-For: 61.146.4.192" localhost:443 | grep City

五.请求头中获取所属区域

http://www.jsqmd.com/news/576708/

相关文章:

  • AQRC智金未来:全球资产配置的算法革命已来
  • 如何提高YOLO8目标检测的准确性?
  • 中国主要农作物生长发育数据集(V2.0)谁有
  • 苹果 50 年:品味如何定义产品与行业格局
  • C++ 工厂模式(转载)
  • 课灵h5p-标签页 (Tabs)教程
  • 矿明 102V 开发板进入U-Booot, uatr-boot 烧录模式____进行烧录升级
  • 【AI】AI安全工具:AI应急响应工具的使用与配置
  • OpenClaw安全实践:千问3.5-9B本地化处理敏感财务数据
  • 突破语言壁垒:PotPlayer实时字幕翻译插件让跨语言视频效率提升300%
  • 5步搞定Jimeng LoRA测试台:Streamlit界面,LoRA版本智能排序
  • ViGEmBus驱动全攻略:解锁游戏控制新可能
  • 腾讯阿里都在用!国内大厂开源20款核心CLI工具,建议开发者收藏!
  • SeamlessM4T v2:跨语言实时对话的终极解决方案与技术实践
  • 一文讲透溢价发行(附计算逻辑+投资理解)
  • Vue表单生成器完全指南:从声明式定义到企业级应用
  • 终极指南:3种方法解锁Netgear路由器隐藏的Telnet控制台
  • MQ 学习笔记
  • 以采购管理系统为例,构建多角色AI智能体协作系统
  • 热水管道选材新思路 替代铜管、不怕水垢腐蚀
  • AI辅助开发:让快马平台用自然语言生成计算机组成原理相关代码
  • Midscene.js:重塑UI自动化的革命性AI视觉驱动方案
  • 3步解锁Navicat无限试用:Mac用户必学的重置技巧
  • Claude Code实战9|250行代码打通飞书CLI与Claude的双向通信结构
  • 基于NGAFID航空数据集的InceptionTime时序分类研究
  • Linux平台微信开发者工具终极指南:快速搭建免费小程序开发环境
  • 如何用AI图像分层工具layerdivider:3分钟完成复杂插画分层
  • 2026预算有限怎么学雅思口语?高性价比线上课程推荐 - 品牌2025
  • 终极视频修复指南:如何使用Untrunc轻松恢复损坏的MP4/MOV文件
  • semi-utils:摄影师的EXIF水印自动化工具——从效率提升到专业呈现