Nginx 升级 OpenSSL 版本

目录

一、操作前准备

1.备份重要文件

2.检查当前版本

3.下载所需安装包

二、编译安装(核心步骤)

1.安装编译依赖

[2.获取原有 Nginx 编译参数](#2.获取原有 Nginx 编译参数)

[3.编译 Nginx(指定新 OpenSSL)](#3.编译 Nginx(指定新 OpenSSL))

三、验证升级结果

四、回滚方案(若升级失败)


一、操作前准备

1.备份重要文件

bash 复制代码
# 备份 Nginx 配置
cp -r /etc/nginx /etc/nginx.bak
# 备份 Nginx 二进制文件
cp /usr/sbin/nginx /usr/sbin/nginx.bak

2.检查当前版本

bash 复制代码
# 查看当前 Nginx 版本和关联的 OpenSSL 版本
nginx -V
# 查看系统自带的 OpenSSL 版本
openssl version

3.下载所需安装包

bash 复制代码
# 下载 OpenSSL 源码
wget https://www.openssl.org/source/openssl-3.0.12.tar.gz
# 下载 Nginx 源码(需和当前运行版本一致,或升级 Nginx 同时升级)
wget http://nginx.org/download/nginx-1.24.0.tar.gz

# 解压包
tar -zxf openssl-3.0.12.tar.gz
tar -zxf nginx-1.24.0.tar.gz

二、编译安装(核心步骤)

Nginx 无法直接替换 OpenSSL 动态库,必须重新编译 Nginx 并指定新的 OpenSSL 源码路径。

1.安装编译依赖

bash 复制代码
# CentOS/RHEL 系统
yum install -y gcc gcc-c++ make pcre-devel zlib-devel perl-IPC-Cmd perl-Text-Template perl-Data-Dumper
# Ubuntu/Debian 系统
apt-get install -y gcc g++ make libpcre3-dev zlib1g-dev

2.获取原有 Nginx 编译参数

bash 复制代码
nginx -V 2>&1 | grep -oP '(?<=configure arguments: ).*' > nginx_config_args.txt

执行后会把原有编译参数保存到 nginx_config_args.txt,后续编译需完全复用这些参数,仅新增 OpenSSL 路径

3.编译 Nginx(指定新 OpenSSL)

bash 复制代码
# 进入 Nginx 源码目录
cd nginx-1.24.0

# 执行配置(替换为你的 OpenSSL 路径和原有编译参数)
./configure $(cat ../nginx_config_args.txt) --with-openssl=../openssl-3.0.12

# 编译(-j 后接CPU核心数,加速编译)
make -j4

# 替换 Nginx 二进制文件(软升级,不中断服务)
make upgrade

三、验证升级结果

bash 复制代码
# 检查 Nginx 关联的 OpenSSL 版本
nginx -V | grep openssl

# 示例输出(表示升级成功):
# built with OpenSSL 3.0.12 24 Oct 2023

四、回滚方案(若升级失败)

如果升级后 Nginx 无法启动,立即回滚

bash 复制代码
# 停止异常的 Nginx
systemctl stop nginx

# 恢复备份的二进制文件
cp /usr/sbin/nginx.bak /usr/sbin/nginx

# 恢复配置(如需)
cp -r /etc/nginx.bak/* /etc/nginx/

# 重启 Nginx
systemctl start nginx
相关推荐
lisanmengmeng7 小时前
gitlab 免密配置
linux·服务器·gitlab
普马萨特7 小时前
Wi-Fi (802.11) 协议演进
运维·服务器·网络
与代码不die不休7 小时前
RTX5060显卡torch和torch_radon库安装避坑指南(仅linux系统)
linux·图像处理·python·深度学习
vortex57 小时前
深入探讨 Linux/Unix 传统设计哲学
linux·运维·unix
袁小皮皮不皮7 小时前
2.HCIP OSPF路由基础(优化版)
运维·服务器·网络·网络协议·智能路由器
vsropy7 小时前
Ubuntu20 ping: www.baidu.com: 域名解析暂时失败的解决办法
运维·服务器
火山上的企鹅7 小时前
Codex实战:APP远程升级服务搭建(二)阿里云ECS部署Node升级服务_Ubuntu_systemd_Nginx
nginx·ubuntu·阿里云·qgc
不吃土豆的马铃薯7 小时前
C++ 正则表达式入门详解
linux·服务器·网络·数据库·c++·正则表达式
xcLeigh8 小时前
鸿蒙平台 NixNote2 富文本笔记应用适配实战:从 Linux 到 鸿蒙PC 的 Electron 迁移
linux·笔记·harmonyos·富文本·nixnote2·evernote
kdxiaojie8 小时前
Linux 驱动研究 —— SPI (2)
linux·运维·笔记·学习