【总结】nginx源码编译安装报错./configure: error: SSL modules require the OpenSSL library.

问题现象

源码编译安装nginx时,执行./configure ...... --with-http_ssl_module 命令安装https模块,需要用到openssl,由于机器缺少openssl库,报如下错误。

复制代码
......
checking for openat(), fstatat() ... found
checking for getaddrinfo() ... found
checking for PCRE2 library ... not found
checking for PCRE library ... found
checking for PCRE JIT support ... found
checking for OpenSSL library ... not found
checking for OpenSSL library in /usr/local/ ... not found
checking for OpenSSL library in /usr/pkg/ ... not found
checking for OpenSSL library in /opt/local/ ... not found

./configure: error: SSL modules require the OpenSSL library.
You can either do not enable the modules, or install the OpenSSL library
into the system, or build the OpenSSL library statically from the source
with nginx by using --with-openssl=<path> option.

排查分析

因为机器不能连接外网,采用离线安装rpm 包的方式,安装openssl

从网上下载了:

openssl-1.0.2k-26.el7_9.x86_64.rpm

openssl-devel-1.0.2k-26.el7_9.x86_64.rpm

使用以下命令安装:
sudo rpm -ivh openssl-1.0.2k-26.el7_9.x86_64.rpm --nodeps --force
sudo rpm -ivh openssl-devel-1.0.2k-26.el7_9.x86_64.rpm --nodeps --force

openssl安装后,openssl命令正常。但是执行./configure ...... --with-http_ssl_module 还是报一样的错误。

在网上搜罗了一堆方法,改各种文件,都没有生效。

此时,严重怀疑是使用rpm 离线安装openssl库时,由于使用了--nodeps --force 这两个指令,忽略了openssl的依赖库,强制安装。导致openssl某些依赖,没有安装成功,从而导致openssl不可用。

于是再次认真阅读提示信息: or build the OpenSSL library statically from the source with nginx by using --with-openssl= option.

那就尝试一下吧,使用openssl源码静态库的方式来编译nginx。

解决方法

从openssl官网下载源码,使用--with-openssl= 的方式来编译安装。

下载地址:https://www.openssl.org/source/old/index.html

本人使用的centos 7,下载的是1.1.0k这个版本。

下载后解压,假如此处解压的目录是:/data/openssl-1.1.0k

那么执行:./configure --prefix=/data/nginx --with-http_stub_status_module --with-http_ssl_module --with-openssl=/data/openssl-1.1.0k

以上命令,可顺利通过。

接下来,执行:make && make install 就顺利编译通过了。

总结

  • 原因:可能是使用rpm 离线安装openssl库时,由于使用了--nodeps --force 这两个指令,忽略了openssl的依赖库,强制安装。导致openssl某些依赖,没有安装成功,从而导致openssl不可用。
  • 解决方法
    1)下载openssl 源码包
    2)解压到指定目录/data/openssl-1.1.0k
    3)执行./configure 时,添加--with-openssl=/data/openssl-1.1.0k参数

至此,问题成功解决。

相关推荐
萧曵 丶1 天前
Nginx常用配置
运维·nginx
有代理ip1 天前
后端服务安全加固:Nginx 反向代理配置教程
运维·nginx·安全
养多肉1 天前
宝塔面板绑定域名(不带端口)
服务器·nginx·安全
鹏大师运维1 天前
统信 UOS OpenSSL 漏洞如何修复?外网 / 内网两种方式一次讲清
linux·运维·openssl·国产操作系统·统信uos·麒麟桌面操作系统·补丁修复
小麻侬1 天前
CMake gui构建libcurl,MTD/MT,支持openssl
openssl·libcurl·cmake gui
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.2 天前
Nginx构建PC站点:root与alias详解
运维·chrome·nginx
前进的程序员2 天前
OpenSSL加解密原理及使用方法详解
ssl·加解密·openssl
哆啦code梦2 天前
Kong vs Nginx:微服务网关选型指南
nginx·kong·微服务网关
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.2 天前
Nginx性能调优与压测实战指南
运维·nginx
岁岁种桃花儿2 天前
流量入口Nginx动态发现K8s Ingress Controller实操指南
nginx·架构·kubernetes