/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 加载,所有用户态进程(包括 lsps 甚至 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。这

样即使 root 用户也无法修改或删除,除非先执行 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解析【教程】  如何在万网自助建站中设置域名及备案?