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

14次阅读

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,但难以完全同步所有文件的时间属性:

  • 执行 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) 是否严重不一致,该差异无法通过普通用户态命令抹平
text=ZqhQzanResources