/etc/ld.so.preload 被篡改导致全局加载恶意 so 的检测清理
发布时间 - 2026-01-26 00:00:00 点击率:次直接查看文件内容可快速判断:cat /etc/ld.so.preload,若非空(如含/tmp/.x.so)即被篡改;该文件默认不存在或为空,且权限不应开放写入,属主应为root,否则属异常。
怎么确认 /etc/ld.so.preload 被篡改了
直接查看文件内容是最快速的判断方式:cat /etc/ld.so.preload。如果输出非空(比如出现类似 /tmp/.x.so 或 /var/tmp/libhook.so 的路径),基本可断定已被植入。该文件本应为空或根本不存在——Linux 默认不创建它,任何内容都属于异常。
还要注意权限和属主:ls -l /etc/ld.so.preload。正常情况不该有写权限(尤其对 non-root 用户),若看到 -rw-rw-rw- 或属主是 daemon/nobody,就是强信号。
- 该文件被读取时机极早:在
main()执行前,由动态链接器ld-linux.so加载,所有用户态进程(包括ls、ps甚至bash)都会强制加载其中指定的 so - 恶意 so 常驻内存后,可能绕过常规进程检测(
ps看不到独立进程,但lsof -nP -p 1可能暴露异常库) - 有些后门会用绝对路径指向已删除文件(
/dev/shm/.a.so (deleted)),这时cat看不到内容,但readlink /proc/1/map_files/...或gdb -p 1 -ex 'info sharedlibrary' -ex quit才能发现
ld.so.preload 里写的路径为什么能生效
因为 glibc 的动态链接器硬编码了这个路径查找逻辑:只要文件存在且格式合法(ELF shared object)、有执行权限、符号表可解析,就会在每个进程启动时优先 dlopen() 它。它不校验签名,不检查是否在 LD_LIBRARY_PATH 中,也不受 secure-execution 模式限制(除非系统启用了 AT_SECURE 且 preloaded so 不满足 setuid 安全要求)。
这意味着哪怕你用 strace -e trace=openat,openat64 /bin/true,也看不到对那个 so 的 open 调用——它是链接器内部行为,不是用户代码发起的。
- 相对路径无效:必须是绝对路径,否则加载失败(
ld直接报cannot open shared object file) - 路径中不能含空格或特殊 shell 字符,否则解析中断,整行被跳过(但其他行仍有效)
- 多行支持:每行一个 so,空行和以
#开头的行会被忽略
清理时要同步处理的三个关键点
删掉 /etc/ld.so.preload 只是第一步。攻击者往往配套部署多个落点,只清文件等于留后门。
- 检查对应 so 文件是否还在磁盘:
ls -la $(cat /etc/ld.so.preload 2>/dev/null | head -n1);若显示(deleted),说明已被 rm 但句柄仍被进程占用,需找出处(lsof | grep deleted)并 kill 相关进程 - 检查 cron、systemd timer、
/etc/init.d/脚本里是否有自动恢复该文件的逻辑(常见于定时任务里echo "/tmp/x.so" > /etc/ld.so.preload) - 查 rootkit 是否已 hook
open()或stat()系统调用:用静态编译的busybox ls或从 Live CD 挂载根分区再检查,避免被运行时劫持干扰判断
如何防止再次被写入
最直接有效的是加不可变属性:chattr +i /etc/ld.so.preload。这

chattr -i。注意:该操作要求文件系统支持 ext2/3/4/xfs 等,btrfs 不支持 +i,zfs 需用 chmod A- 或设置 readonly=on。
如果系统不允许加锁(如容器环境或某些云主机),至少确保文件不存在且父目录权限收紧:rm -f /etc/ld.so.preload && chmod 755 /etc,并加入定期校验(例如用 sha256sum /etc/ld.so.preload 2>/dev/null || echo "missing")。
真正难防的是攻击者已获得 root 权限——此时他可以卸载文件系统、绕过 chattr、甚至 patch 内核。所以重点不在“怎么锁死”,而在“怎么早发现”:把 /etc/ld.so.preload 加入 HIDS(如 aide、samhain)监控列表,或用 inotifywait -m -e create,modify /etc 做实时告警。
别忘了检查 /etc/ld.so.cache 和 /etc/ld.so.conf.d/ 下的配置,它们虽不等同于 preload,但也可被用来持久化恶意库路径,且更隐蔽。
# linux
# 编码
# ai
# 为什么
# red
# bash
# echo
# Object
# NULL
# var
# 该文件
# 不存在
# 的是
# 已被
# 加载
# 文件系统
# 为空
# 就会
# 还在
# 多个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
郑州企业网站制作公司,郑州招聘网站有哪些?
微信推文制作网站有哪些,怎么做微信推文,急?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
Java垃圾回收器的方法和原理总结
黑客如何通过漏洞一步步攻陷网站服务器?
bootstrap日历插件datetimepicker使用方法
Laravel如何处理文件下载请求?(Response示例)
怎么用AI帮你为初创公司进行市场定位分析?
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】
制作企业网站建设方案,怎样建设一个公司网站?
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
Laravel怎么导出Excel文件_Laravel Excel插件使用教程
如何快速搭建FTP站点实现文件共享?
Laravel如何创建自定义中间件?(Middleware代码示例)
如何自定义建站之星网站的导航菜单样式?
Bootstrap整体框架之CSS12栅格系统
网站制作价目表怎么做,珍爱网婚介费用多少?
教你用AI将一段旋律扩展成一首完整的曲子
浅谈Javascript中的Label语句
如何在IIS7中新建站点?详细步骤解析
php json中文编码为null的解决办法
微信小程序 闭包写法详细介绍
深入理解Android中的xmlns:tools属性
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
,南京靠谱的征婚网站?
怎么用AI帮你设计一套个性化的手机App图标?
Laravel如何实现用户密码重置功能?(完整流程代码)
如何在阿里云虚拟服务器快速搭建网站?
深圳网站制作培训,深圳哪些招聘网站比较好?
如何在云主机上快速搭建多站点网站?
如何用免费手机建站系统零基础打造专业网站?
Laravel如何与Inertia.js和Vue/React构建现代单页应用
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
实现点击下箭头变上箭头来回切换的两种方法【推荐】
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
北京网站制作公司哪家好一点,北京租房网站有哪些?
如何在自有机房高效搭建专业网站?
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
如何基于云服务器快速搭建网站及云盘系统?
Java解压缩zip - 解压缩多个文件或文件夹实例
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Python面向对象测试方法_mock解析【教程】
如何在万网自助建站中设置域名及备案?

