用 LD_PRELOAD 挽救被误删的 libc.so.6
用 LD_PRELOAD 挽救被误删的 libc.so.6
libc.so.6 的符号链接被同事误删,。
libc.so.6,不仅包含了普通的 C 运行库,还包含了系统调用的封装。
就像 Windows 系统上的 kernel32.dll 一样重要。被误删后,几乎所有新的进程都起不来,因为几乎所有的程序都依赖 libc.so.6。
因此 scp, cz, cp, ln 统统不管用。
用写一个这样的文件或许有效。
$ cat /usr/lib/libc.so
/* GNU ld script
Use the shared library, but some functions are only in
the static library, so try that secondarily. */
OUTPUT_FORMAT(elf32-i386)
GROUP ( /lib/libc.so.6 /usr/lib/libc_nonshared.a AS_NEEDED ( /lib/ld-linux.so.2 ) )
当时不记得
原始文件还在
lrwxrwxrwx 1 root root 11 2009-06-02 16:14 /lib/libc.so.6 -> libc-2.4.so
于是,后来想起 LD_PRELOAD,
$ LD_PRELOAD=/lib/libc-2.4.so ln -s /lib/libc-2.4.so /lib/libc.so.6
就 OK 了。
Linux 包括一些 Solaris 等 Unix,会从 LD_PRELOAD 变量预先加载 so,因为 libc-2.4.so 就是 libc.so.6 的实体,所以加载后
所有的符号都解决了。LD_PRELOAD 本来是可以用于 hook 函数等目的。没想到关键时刻还能救人一命。
建议继续学习:
- MySQL从压缩文件恢复数据 (阅读:3758)
- 参数_smon_internal_errlimit与数据库恢复 (阅读:3247)
- MySQL 备份和其恢复机制原理简述 (阅读:3199)
- 用bin日志中恢复MySQL数据库 (阅读:2701)
- 用CloneZilla制作紧急恢复分区 (阅读:2660)
- Zmanda让MySQL的备份与恢复更加方便快捷灵活 (阅读:2344)
- 当logfile被误删除后 (阅读:2206)
- EXT文件系统误删除数据恢复指南 (阅读:2234)
- Oracle数据库恢复:存储故障导致的数据损坏 (阅读:2073)
- Oracle数据库恢复:归档日志损坏案例一则 (阅读:1968)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:陈峰 来源: chen3feng的专栏
- 标签: LD_PRELOAD 恢复
- 发布时间:2010-07-23 00:06:31
- [70] Twitter/微博客的学习摘要
- [68] IOS安全–浅谈关于IOS加固的几种方法
- [66] 如何拿下简短的域名
- [65] android 开发入门
- [64] find命令的一点注意事项
- [63] Go Reflect 性能
- [61] 流程管理与用户研究
- [60] Oracle MTS模式下 进程地址与会话信
- [59] 图书馆的世界纪录
- [58] 读书笔记-壹百度:百度十年千倍的29条法则