强制卸载openssl-libs导致系统异常的修复方法

openssl升级比较麻烦,因为很多软件都会依赖它,一旦强制卸载(尤其是openssl-libs.rpm),就可能导致很多命令不可用,即使想用rpm命令重新安装都不行。

所以,除非万不得已,否则不要轻易去卸载openssl-libs。而且,以下修复方法也不见得对每个场景都有效。

我之所以要强制卸载openssl-libs,也是因为要升级它,升级包安装之后,版本没有变化,所以,一怒之下,把openssl相关的包全都给强制卸载了,然后悲剧就发生了。连重装的机会都没有了,输入rpm命令,直接报如下错误:

bash 复制代码
rpm: error while loading shared libraries: libcrypto.so.1.1: cannot open shared object file: No such file or directory,

其实,我干这种事情也不是一次两次,因为是实验室环境,所以可以放心大胆的折腾。每次搞挂了,就重装系统。突然有一天想试试能不能修复一下,于是搜索各种案例,最终发现如下方法对我有效。但,前提是,当前终端窗口不关闭。如果终端窗口也关闭了,那估计就没有挽救的机会了,考虑重装吧,😂。

言归正传,进入修复步骤:

1、用whereis libcrypto 命令验证符号链接目标文件是否存在,如果whereis命令不好用,那就换find / -name libcrypto.so 2>/dev/null 命令来查找。

如果能找到,则在/usr/liba64下有该文件:

bash 复制代码
[root@~ lib64]# ll |grep   libcrypto.so
lrwxrwxrwx   1 root root       33 May 16 19:30 libcrypto.so -> /usr/openssl/lib/libcrypto.so.1.1

能找到上面的文件,则说明文件并没有被删掉,可能是动态链接库的信息没有了。

2、验证库是否被加载:

bash 复制代码
ldconfig -p | grep libcrypto.so.1.1

如果输出为空,那就需要重新更新动态链接库缓存。将该路径添加到动态链接库配置中:

bash 复制代码
echo "/usr/openssl/lib" > /etc/ld.so.conf.d/openssl.conf

然后更新动态链接库缓存:

bash 复制代码
ldconfig

再次验证库是否已被加载:

bash 复制代码
ldconfig -p | grep libcrypto.so.1.1

如果有输出结果,那就大功告成了。

相关推荐
Johny_Zhao14 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
YuMiao1 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
chlk1232 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑2 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件2 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
碳基沙盒2 天前
OpenClaw 多 Agent 配置实战指南
运维
深紫色的三北六号3 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash3 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI3 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行4 天前
Linux和window共享文件夹
linux