OpenSSL安装/升级 版本(1.1.1q)

本文提供了升级OpenSSL到1.1.1q稳定版的步骤,包括下载源码、编译安装、替换老版本以及解决动态库链接问题。在升级后,可能需要更新系统路径并执行ldconfig以确保新版本生效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:https://zhuanlan.zhihu.com/p/581995964
防止原文丢失,这里做了转载,内容如下.


注意:2022年11月 最新的稳定版本是1.1.1q系列(https://www.openssl.org/source/)

升级步骤

  1. 查看openssl版本,目前是1.0版本系列
    openssl version
    在这里插入图片描述

  2. 下载最新稳定版本的OpenSSL源码包
    wget https://www.openssl.org/source/openssl-1.1.1q.tar.gz

  3. 编译源码安装
    tar -xzvf openssl-1.1.1q.tar.gz
    cd openssl-1.1.1q
    ./config --prefix=/usr/local/openssl
    make && make install

在这里插入图片描述
4. 查看是否安装成功
/usr/local/openssl/bin/openssl version -a

在这里插入图片描述
5. 替换老版本的 openssl
mv /usr/bin/openssl /usr/bin/openssl.bak
mv /usr/include/openssl /usr/include/openssl.bak

ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl
ln -s /usr/local/openssl/include/openssl /usr/include/openssl

  1. 查看是否安装成功
    openssl version -a
    在这里插入图片描述

遇到的问题

版本未改变, 还是旧版本的 openssl
然后再次执行 openssl version 查看会发现还是 OpenSSL 1.0.2k-fips 版本。
出现这情况并不是没有升级成功。而是该会话还是原来的会话端重新开启新的会话即可。无需重启机器。
在这里插入图片描述
开启新的会话执行 openssl version 查看则显示为升级后的版本。
在这里插入图片描述
openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory
说明:升级后如果执行 openssl version 命令出现openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory错误。

执行以下命令即可:
ln -s /usr/local/openssl/lib/libssl.so.1.1 /usr/lib64/libssl.so.1.1
ln -s /usr/local/openssl/lib/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1

echo “/usr/local/openssl/lib” >> /etc/ld.so.conf
ldconfig

在这里插入图片描述

### 如何将 OpenSSL 库从 1.1.1f 版本升级1.1.1q #### 准备工作 在执行任何操作之前,建议备份当前环境中的配置文件和其他重要数据。这可以防止意外的数据丢失。 #### 更新包管理器缓存并安装依赖项 为了确保获取最新的软件包列表以及必要的构建工具,在开始编译新版本前应更新本地仓库索引并安装所需开发库: 对于基于 Red Hat 的系统(如 CentOS 或 RHEL),可运行如下命令来准备环境: ```bash sudo yum update -y && sudo yum groupinstall "Development Tools" -y ``` 对于 Debian 及其衍生发行版(如 Ubuntu),则需执行以下指令完成相同目的: ```bash sudo apt-get update -y && sudo apt-get install build-essential checkinstall -y ``` #### 下载指定版本源码 前往官方 GitHub 页面下载目标版本 tarball 文件,这里以 v1.1.1q 为例说明具体做法: ```bash wget https://github.com/openssl/openssl/archive/OpenSSL_1_1_1q.tar.gz tar zxvf OpenSSL_1_1_1q.tar.gz cd openssl-OpenSSL_1_1_1q/ ``` #### 配置与编译项目 按照官方文档指导进行配置选项设置,并启动 Makefile 构建流程: ```bash ./config --prefix=/usr/local/ssl shared zlib-dynamic make depend make ``` #### 安装新的 OpenSSL 实例 通过 `checkinstall` 工具代替传统的 `make install` 命令来进行打包部署,这样可以在卸载时更加方便地移除已安装组件而不破坏原有系统结构: ```bash sudo checkinstall make INSTALL_PREFIX=/tmp/_inst install ``` 如果未安装 `checkinstall` ,也可以直接使用 `make install` 来完成最后一步安装过程,但这可能会覆盖现有的 OpenSSL 安装[^2]。 #### 修改默认路径指向新版 OpenSSL 为了让整个操作系统能够识别刚刚安装的新版本 OpenSSL,默认情况下可能还需要调整一些链接关系或者修改环境变量 PATH 中的位置顺序让 `/usr/local/bin` 排在更前面;另外一种方法就是创建软连接使得旧位置指向最新版本二进制文件所在目录下的对应名称程序。 #### 测试验证 重启服务或重新登录使更改生效后,可以通过下面这条简单的 shell 脚本来测试是否成功切换到了期望的版本号上: ```bash openssl version ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值