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

在 Nginx Docker 官方镜像中编译并加入第三方模块 - 教程

在启用 Nginx 官方 Docker 镜像时,默认不包含第三方模块。假如我们希望实现根据国家或城市限制 IP 访问 等功能,就需要手动编译并添加第三方模块。本文以 ngx_http_geoip2_module 为例,详细介绍如何在 Nginx Docker 容器中完成编译和使用。​​​​​​

一、问题背景

  • Nginx 官方 Docker 镜像比较精简,默认删除了编译依赖。

  • 一些第三方模块(如 GeoIP2)需要依赖库支持。

  • 因此要求修改 Dockerfile,让镜像保留构建设备,再进入容器编译安装模块。


二、基础镜像准备

  1. 下载官方镜像文件

  • Docker Hub 官方 Nginx 镜像库:https://hub.docker.com/_/nginx

  • GitHub 官方 Nginx Docker 资料:https://github.com/nginxinc/docker-nginx/

  1. 修改 Dockerfile

  • 进入 docker-nginx-master/mainline/debian 文件夹。

  • 编辑 Dockerfile,将清理安装包的语句替换为安全占位符,例如:

    RUN touch 1.txt && rm -rf 1.txt

  1. 构建镜像

docker build -t nginx-geoip2:1.21.3 .


三、准备依赖与源码

  • Nginx 同版本源码包:http://nginx.org/download/
    nginx-1.21.3.tar.gz

  • GeoIP2 模块源码包:
    https://github.com/TravelEngineers/ngx_http_geoip2_module
    ngx_http_geoip2_module-master.zip

  • GeoIP2 依赖库(libmaxminddb):
    https://github.com/maxmind/libmaxminddb/releases
    libmaxminddb-1.6.0.tar.gz

  • MaxMind GeoIP2 数据库:

    • GeoLite2-Country_20211005.tar.gz

    • GeoLite2-City_20211005.tar.gz


四、容器内编译安装

  1. 启动容器

docker run -d -t --name nginx --restart=always -p 80:80 nginx-geoip2:1.21.3

  1. 复制文件到容器

docker cp libmaxminddb-1.6.0 nginx:/

docker cp ngx_http_geoip2_module-master nginx:/

docker cp nginx-1.21.3 nginx:/usr/local/

  1. 安装依赖库 libmaxminddb

apt update && apt install -y build-essential make

cd libmaxminddb-1.6.0/

./configure && make && make check && make install

ldconfig

  1. 准备模块目录

mkdir -p /usr/lib/nginx/nginx-geoip2

mv /ngx_http_geoip2_module-master /usr/lib/nginx/nginx-geoip2/ngx_http_geoip2_module

  1. 安装 Nginx 编译依赖

apt-get install -y libpcre3 libpcre3-dev libssl-dev zlib1g-dev

/usr/sbin/nginx -V # 查看原始编译参数

  1. 重新编译 Nginx,添加模块

cd /usr/local/nginx-1.21.3

./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx \

...原有参数... \

--add-module=/usr/lib/nginx/nginx-geoip2/ngx_http_geoip2_module

make

cp /usr/sbin/nginx /usr/sbin/nginx-no-geoip2

cp /usr/local/nginx-1.21.3/objs/nginx /usr/sbin/nginx

  1. 验证是否成功

docker restart nginx

docker exec -it nginx /bin/bash

/usr/sbin/nginx -V # 输出应包含 geoip2 模块

ldd /usr/sbin/nginx # 应包含 libmaxminddb.so.0


五、配置 GeoIP2 数据库

  1. 导入 MaxMind 数据库

tar -zxvf GeoLite2-Country_20211005.tar.gz

tar -zxvf GeoLite2-City_20211005.tar.gz

docker cp GeoLite2-City_20211005/GeoLite2-City.mmdb nginx:/usr/share/nginx/

docker cp GeoLite2-Country_20211005/GeoLite2-Country.mmdb nginx:/usr/share/nginx/

  1. 修改 Nginx 配置文件
    nginx.conf 中添加:

load_module modules/ngx_http_geoip2_module.so;

http {
geoip2 /usr/share/nginx/GeoLite2-Country.mmdb {
$geoip2_country_code default=US source=$remote_addr country iso_code;
}

server {
listen 80;

location / {
if ($geoip2_country_code ~ (US|NL|GB)) {
return 403;
}
root /usr/share/nginx/html;
}
}
}

  1. 验证配置

nginx -t

nginx -s reload

http://www.rkmt.cn/news/12440.html

相关文章:

  • 计算机毕业设计springboot考研资讯管理系统 基于Spring Boot的考研信息管理平台设计与达成 Spring Boot驱动下的研究生入学考试资讯管理系统开发
  • 【IEEE出版 | 南工大主办 | 稳定EI检索】第二届自动化、电气控制系统与设备国际学术会议(AECSE 2025)
  • Matlab通过GUI建立点云的最远点下采样(Farthest point sampling)
  • AutoMQ Ververica:打造云原生实时数据流最佳实践! - 教程
  • Java外功基础(1)——Spring Web MVC - 指南
  • C#/.NET/.NET Core技术前沿周刊 | 第 55 期(2025年9.15-9.21) - 实践
  • 2025年混凝搅拌机优质供应商推荐厂家/混凝搅拌机源头工厂/哪家强?
  • spring源码阅读之bean加载过程(一)
  • concurrenthashmap为什么get方法不需要加锁呢
  • Prometheus_basic_auth
  • JAVA变量
  • Winform程序中将datagridview导出到excel (推荐)
  • 第二章Pycharm和Jupiter
  • 微服务基础3-服务保护与分布式事务 - 详解
  • 剖析布谷相亲婚恋交友app源码之关键论述
  • 将网站展示图片的格式由 JPG 切换到了 WebP
  • Python 标准库 typing 类型注解标注
  • 从方向向量获取y轴旋转值
  • verilog一些操作符和特殊函数
  • 20250820_浙江省职业职工技能竞赛_crypto
  • 第一章pytorch安装
  • 深入解析:i.MX6ULL移植内核6.6(一)修改网络驱动和LCD驱动
  • 【MySQL】XML中基于已有查询代码,进一步做汇总统计
  • 别再一张证件照用到底了,我建了个“个人形象库”
  • 【SPIE出版】第七届地球科学与遥感测绘国际学术会议(GRSM 2025)
  • ARL(灯塔)安装步骤--超简单!!
  • 基于MATLAB的经典车辆路径问题(VRP)求解方法详解
  • 14种纯css3对话气泡样式代码
  • AI agent编程随记
  • 再见 Claude Code!玩转 CodeX CLI 的 16 个实用小技巧,效率拉满!!