Openssl升级

1、查看当前openssl版本

bash 复制代码
[root@10 ~]# openssl version -a
OpenSSL 1.0.2k-fips  26 Jan 2017
built on: reproducible build, date unspecified
platform: linux-x86_64
options:  bn(64,64) md2(int) rc4(16x,int) des(idx,cisc,16,int) idea(int) blowfish(idx) 
compiler: gcc -I. -I.. -I../include  -fPIC -DOPENSSL_PIC -DZLIB -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -DKRB5_MIT -m64 -DL_ENDIAN -Wall -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches   -m64 -mtune=generic -Wa,--noexecstack -DPURIFY -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DRC4_ASM -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DWHIRLPOOL_ASM -DGHASH_ASM -DECP_NISTZ256_ASM
OPENSSLDIR: "/etc/pki/tls"
engines:  rdrand dynamic

2、备份重要数据

bash 复制代码
[root@10 ~]# cp -r /etc/ssl /etc/ssl_backup
[root@10 ~]# cp /usr/bin/openssl /usr/bin/openssl_backup

3、手动下载openssl包

bash 复制代码
[root@10 ~]# cd /tmp
[root@10 ~]# wget https://www.openssl.org/source/openssl-1.1.1k.tar.gz
[root@10 ~]# tar -zxvf openssl-1.1.1k.tar.gz
[root@10 ~]# cd openssl-1.1.1k

4、编译安装

bash 复制代码
[root@10 openssl-1.1.1k]# ./config --prefix=/usr/local/openssl --openssldir=/usr/local/openssl shared zlib
[root@10 openssl-1.1.1k]# make -j$(nproc)
[root@10 openssl-1.1.1k]# make install

5、更新系统链接

5.1、备份旧版本

bash 复制代码
[root@10 openssl-1.1.1k]# mv /usr/bin/openssl /usr/bin/openssl.old
[root@10 openssl-1.1.1k]# mv /usr/include/openssl /usr/include/openssl.old

5.2、创建新链接

bash 复制代码
[root@10 openssl-1.1.1k]# ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl
[root@10 openssl-1.1.1k]# ln -s /usr/local/openssl/include/openssl /usr/include/openssl

5.3、更新动态链接库

bash 复制代码
[root@10 openssl-1.1.1k]# echo "/usr/local/openssl/lib" | sudo tee /etc/ld.so.conf.d/openssl.conf
[root@10 openssl-1.1.1k]# ldconfig -v

6、验证版本

bash 复制代码
[root@10 openssl-1.1.1k]# openssl version -a
[root@10 openssl-1.1.1k]# openssl version -a
OpenSSL 1.1.1k  25 Mar 2021
built on: Mon Jun 30 15:12:41 2025 UTC
platform: linux-x86_64
options:  bn(64,64) rc4(16x,int) des(int) idea(int) blowfish(ptr) 
compiler: gcc -fPIC -pthread -m64 -Wa,--noexecstack -Wall -O3 -DOPENSSL_USE_NODELETE -DL_ENDIAN -DOPENSSL_PIC -DOPENSSL_CPUID_OBJ -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DKECCAK1600_ASM -DRC4_ASM -DMD5_ASM -DAESNI_ASM -DVPAES_ASM -DGHASH_ASM -DECP_NISTZ256_ASM -DX25519_ASM -DPOLY1305_ASM -DZLIB -DNDEBUG
OPENSSLDIR: "/usr/local/openssl"
ENGINESDIR: "/usr/local/openssl/lib/engines-1.1"
Seeding source: os-specific

7、常见问题

7.1、命令找不到

bash 复制代码
# 添加OpenSSL路径到环境变量
echo 'export PATH="/usr/local/openssl/bin:$PATH"' >> ~/.bashrc
source ~/.bashrc

7.2、动态链接库错误

bash 复制代码
#手动加载动态库
export LD_LIBRARY_PATH=/usr/local/openssl/lib:$LD_LIBRARY_PATH

7.3、缺少 zlib 开发库

bash 复制代码
Centos
yum install zlib-devel
Ubuntu
apt-get install zlib1g-dev

8、回滚旧版本

bash 复制代码
[root@10 ~]# mv /usr/bin/openssl.old /usr/bin/openssl
[root@10 ~]# mv /usr/include/openssl.old /usr/include/openssl
[root@10 ~]# rm /etc/ld.so.conf.d/openssl.conf
[root@10 ~]# ldconfig -v
相关推荐
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
绵绵细雨中的乡音8 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
暖馒10 小时前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
yunfuuwqi11 小时前
OpenClaw✅真·喂饭级教程:2026年OpenClaw(原Moltbot)一键部署+接入飞书最佳实践
运维·服务器·网络·人工智能·飞书·京东云
迎仔11 小时前
C-算力中心网络隔离实施方法:怎么搞?
运维·网络
代码游侠11 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
枷锁—sha12 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Zach_yuan13 小时前
深入浅出 JSONCpp
linux·服务器·网络·c++
迎仔14 小时前
B-算力中心网络隔离的必要性:为什么必须隔离?
网络
野指针YZZ15 小时前
一键配置RK3588网络与SSH远程连接
网络·ssh·rk3588