1. 背景
- 运行一个binary 应用程序, 提示报错:
- /lib/x86_64-linux-gnu/libm.so.6: version `GLIBC_2.27' not found (required by 我的应用程序
- string 里一下符号标, 确实没有
- 然后下载了一个 glibc-2.27, 安装到 usr/local/下, 并将 libm-2.27.so 和 libc-2.27.so 复制到 /lib/x86_64-linux-gnu目录下
- 并在/lib/x86_64-linux-gnu中 建立软链接
-
之前: libm.so.6 -> libm-2.23.so , libc.so.6 -> libc-2.23.so
-
修改: libm.so.6 -> libm-2.27.so , libc.so.6 -> libc-2.27.so
-
- 并在/lib/x86_64-linux-gnu中 建立软链接
- 此时,出问题了:
- 系统大部分命令 ls ln sudo 都不能使用了
- 在终端 export LD_PRELOAD=/lib/x86_64-linux-gnu/ libc-2.23.so, 即修改回原来的库文件, 此时 ls可以用了, 但是 sudo 却还是用不了, 想用 ln -sf 命令 重新修改会系统原有的库链接, 也提示 Segmentation fault 或者 Permission denied
2. 解决方法
使用u盘启动盘 (重启系统, F12 /DEL/F2/等进入BIOS), 在U盘的系统中进入电脑, 找到目录 对应的/lib/x86_64-linux-gnu 目录,
执行下面命令, 修改会系统的原始链接.
sudo ln -sf libm-2.23.so libm.so.6
sudo ln -sf libc-2.23.so libc.so.6
3. 总结
当系统底层库出现缺少符号时, 不要单独升级某个文件,这可能导致各种不兼容问题,建议整体升级系统的库文件, 比如使用系统自带的指令进行系统更新!
参考:
记录一次libc.so.6文件被替换、删除引发的系统级故障之修复过程-CSDN博客
误删 libc.so.6的解决方法(开机启动不了)_libc.so.6丢失无法开机_Timsley的博客-CSDN博客
软链接libc.so.6错误的修正_如何修改libc.so.6_一个专家程序员的博客-CSDN博客