0

0

Linux 系统时间被恶意修改后如何找入侵痕迹(不依赖 chrony)

冰川箭仙

冰川箭仙

发布时间:2026-01-20 11:10:37

|

883人浏览过

|

来源于php中文网

原创

Linux系统时间被恶意修改可通过多维度时间线索交叉比对定位:检查journal/syslog中时间变更日志、文件元数据异常、登录与进程时间矛盾、RTC与系统时钟偏差等。

linux 系统时间被恶意修改后如何找入侵痕迹(不依赖 chrony)

Linux 系统时间被恶意修改,往往是攻击者为掩盖日志时间戳、绕过时间敏感的检测逻辑(如证书有效期、会话超时、审计窗口)所采取的隐蔽操作。不依赖 chrony 时,仍可通过系统自身留存的多维度时间线索交叉比对,定位异常修改行为和入侵痕迹。

检查系统时间变更历史(/var/log/syslog 或 journal 日志)

系统时间修改会触发内核或 systemd 记录事件,即使未启用 chrony,systemd-timesyncd、date 命令调用或 settimeofday 系统调用都可能留下痕迹:

  • 运行 journalctl -o short-precise | grep -i "time\|clock\|adjtimex\|settimeofday",重点关注包含 “Clock synchronized”、“Time has been changed”、“adjtimex called” 或 “settimeofday” 的条目
  • 若使用 rsyslog,检查 /var/log/syslog/var/log/messages 中类似 “systemd[1]: Time has been changed” 或 “kernel: Clock: inserting leap second”(非闰秒期间出现需警惕)
  • 注意时间戳本身是否被篡改——对比当前真实时间与日志文件的 mtime/ctimels -lc /var/log/syslog),若日志文件的修改时间远早于其末尾记录的时间,说明日志可能被回写或伪造

核查关键时间敏感文件的元数据与内容一致性

攻击者修改系统时间后,常会顺带篡改日志、二进制文件或配置文件的 mtime/ctime/atime,但难以完全同步所有文件的时间属性:

Frase
Frase

Frase是一款出色的长篇 AI 写作工具,快速创建seo优化的内容。

下载
  • 执行 find /var/log -type f -newermt "2024-01-01" ! -newermt "2024-06-01" -ls 2>/dev/null | head -20(替换为你怀疑的时间段),观察日志文件创建/修改时间是否集中出现在某异常短窗口,尤其是凌晨或业务低峰期
  • 检查 /etc/shadow/etc/passwd 的 ctime:stat /etc/shadow,若 ctime 明显早于最近一次密码修改(可查 lastlog 或 auth.log 登录时间),说明文件可能被覆盖或恢复过
  • 对比 last reboot 输出时间与 uptime 推算的启动时间是否矛盾;若 uptime 显示运行了 3 天,但 last 显示上次重启是 1 小时前,说明系统时间曾被大幅倒拨

分析进程与用户行为中的时间异常信号

时间跳变会影响进程生命周期、登录会话、计划任务等,产生违背常理的时间关系:

  • 运行 last -aiF | head -30,查看登录记录的“开始时间”与“结束时间”。若出现“结束时间”早于“开始时间”,或大量会话的持续时间为负值,基本确认系统时间曾被向后大幅调整
  • 检查定时任务:grep -r "^[^#].*run-parts\|date\|touch\|hwclock" /etc/cron* /var/spool/cron 2>/dev/null,特别关注调用 date -shwclock --hctosys 或设置系统时间的脚本——这些可能是攻击者留下的时间重置后门
  • ps -eo pid,ppid,lstart,cmd --sort=lstart | head -20 查看进程启动时间,若发现多个关键服务(sshd、rsyslogd、crond)的 lstart 时间集中在同一秒且明显偏离正常启动序列,提示时间被统一重设过

验证硬件时钟(RTC)与系统时钟偏差

攻击者若仅修改系统时钟(soft clock),硬件时钟(RTC)通常保持原样,二者偏差过大即为强线索:

  • 执行 hwclock --showdate 对比输出,若差值超过 ±5 分钟(尤其在未同步 NTP 的服务器上),且 hwclock --show 时间更符合你预期的真实时间,则系统时钟大概率被人为修改过
  • 进一步运行 hwclock --debug 查看 RTC 读取过程是否异常(如 fallback 到模拟模式、校验失败),某些 rootkit 会 hook rtc_read 隐藏真实 RTC 值
  • 检查 /sys/class/rtc/rtc0/since_epoch(若存在)与 $(cat /proc/sys/kernel/timevalue) 是否严重不一致,该差异无法通过普通用户态命令抹平

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

232

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

436

2024.03.01

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

465

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

13

2025.12.06

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1349

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

703

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

0

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号