当前位置: 首页 > 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.jsqmd.com/news/4410/

相关文章:

  • 计算机毕业设计springboot考研资讯管理系统 基于Spring Boot的考研信息管理平台设计与达成 Spring Boot驱动下的研究生入学考试资讯管理系统开发
  • 登录 Linux 自动展示 CPU/内存/磁盘挂载使用情况等信息(针对于银河麒麟调整的)
  • 解码数据结构线性表之链表
  • C++ placement new
  • Spring Boot接入邮箱,完成邮箱验证码
  • HyperWorks许可与网络安全
  • 高通QCS8550开发板 + DeepSeek-R1:打造智能化商场导购实践
  • 研发项目管理系统哪个好?十款热门工具全面测评
  • L4 vs L7 负载均衡:彻底理解、对比与实战指南 - 实践
  • 《对软件工程的初步理解》
  • 【IEEE出版 | 南工大主办 | 稳定EI检索】第二届自动化、电气控制系统与设备国际学术会议(AECSE 2025)
  • B3863 [GESP202309 一级] 买文具
  • Matlab通过GUI建立点云的最远点下采样(Farthest point sampling)
  • B2009 计算 (a+b)/c 的值
  • 你好 博客园!
  • 详细介绍:【杂谈】Godot 4.5下载指南
  • 2025无人机林业行业场景解决方案
  • 安全帽检测数据集-YOLO格式建筑工地安全图像数据-个人防护装备(PPE)目标检测算法训练-包含安全帽/无安全帽/等多类别标注-深度学习计算机视觉应用-工业安全监控系统开发-实时预警检测模型
  • 实用指南:Spring Boot集群 集成Nginx配置:负载均衡+静态资源分离实战
  • 常用API biginteger和biddecimal
  • WPF ItemsControl implement Select in mvvm via behavior
  • SI3933低频唤醒接收芯片完整指南:结构框图、PCB布局与选型要点芯片概述与主要特性
  • 在本地服务器创建RAID5磁盘阵列和RAID10磁盘阵列
  • RAGAS大模型评估框架
  • 服务器密码错误被锁定如何解决?
  • 螺纹偏弱
  • 水翼式搅拌机推荐品牌/推荐厂家/优质供应商/哪家强?
  • AutoMQ Ververica:打造云原生实时数据流最佳实践! - 教程
  • Java外功基础(1)——Spring Web MVC - 指南
  • 100W QPS:亿级用户的社交关系如何设计?