0

0

Linux 日志中如何发现入侵痕迹?

冷漠man

冷漠man

发布时间:2026-01-30 20:52:01

|

220人浏览过

|

来源于php中文网

原创

查登录日志应先验证时间可信性:通过last/lastb比对uptime、检查负持续会话和btmp清空痕迹;再分析secure/auth.log中的Accepted与Failed密码记录;结合journalctl搜时间变更日志;最后用stat和find交叉验证文件元数据与日志时间一致性。

linux 日志中如何发现入侵痕迹?

查登录日志:从 lastlastb 入手

入侵者最常走的路是 SSH 暴力破解或弱口令登录,lastlastb 是第一道筛子。前者看成功登录,后者看失败尝试——注意时间戳是否“倒流”:比如 last 显示某用户 03:00 登录,但 uptime 显示系统只运行了 2 小时,说明时间被大幅倒拨过,日志可能被篡改。

  • last -aiF | head -20:带 IP、完整时间、纳秒精度,重点看“结束时间早于开始时间”的负持续会话
  • lastb -i | awk '{print $3}' | sort | uniq -c | sort -nr | head -5:统计高频爆破 IP
  • /var/log/btmp 被清空(lastb 无输出),或 ls -l /var/log/btmp 显示 mtime 远早于当前时间,说明攻击者已动手擦除痕迹

盯紧 /var/log/secure/var/log/auth.log

这是 SSH 认证的原始凭证,比 last 更难伪造。攻击者即使清空了 wtmp,也常漏掉它——尤其在 CentOS/RHEL 系统中。

  • grep "Accepted" /var/log/secure | tail -10:找最后几次成功登录,核对 IP 是否可信、时间是否在非工作时段
  • grep "Failed password" /var/log/secure | grep -E "(root|admin|test)":定向排查高危账号爆破行为
  • 警惕 session opened for user root 但没对应 Accepted 记录的情况——可能用了密钥免密登录,需结合 ssh -v 日志或 auth.log 中的 sshd\[.*\]: Connection closed 行交叉验证

journalctl 挖内核与 systemd 时间操作痕迹

系统时间被改,内核和 systemd 几乎一定会记一笔,哪怕没开 chrony。关键不是“有没有同步”,而是“有没有被人工干预”。

Pixso AI
Pixso AI

Pixso AI是一款智能生成设计稿工具,通过AI一键实现文本输入到设计稿生成。

下载
  • journalctl -o short-precise | grep -i "time\|clock\|settimeofday\|adjtimex":搜出所有时间相关事件,重点关注含 "Time has been changed""adjtimex called" 的行
  • 如果发现多条 "Clock synchronized" 在几分钟内密集出现,而你没配 NTP 客户端,大概率是攻击者在反复调校时间以绕过日志时效性检测
  • 检查日志文件自身时间:ls -lc /var/log/journal/*/system.journal,若 journal 文件的 ctime 比其中最早一条日志的时间还晚,说明文件被重建或覆盖过

交叉验证文件元数据与日志内容一致性

攻击者能删日志、改时间,但很难让所有文件的 mtime/ctime 完全同步——这是最隐蔽也最可靠的突破口。

  • stat /etc/shadow /etc/passwd:对比 ctime 与 lastlog -u root 输出的最后登录时间,若 shadow 的 ctime 早于 lastlog 时间 3 天以上,说明密码文件可能被恢复或替换过
  • find /var/log -type f -newermt "2026-01-20" ! -newermt "2026-01-25" -ls 2>/dev/null | head -15:查指定时间段内集中修改的日志文件,若 securemessagesaudit.log 全部在同 10 分钟内被更新,基本可断定是人为清理
  • ls -lt /var/log/*.log | head -5:正常系统日志按轮转规则更新,时间应呈阶梯状;若全部并列在凌晨 2:17,那不是巧合,是脚本批量 touch 过
时间跳变本身就会留下逻辑断层,比如进程启动时间早于系统启动时间、日志条目时间戳乱序、last 记录的登录时间比 uptime 推算的开机时间还早——这些都不是配置问题,是入侵动作撕开的时间裂痕。别只盯着“有没有异常 IP”,先确认“时间本身还是否可信”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.09.27

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

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

237

2023.09.22

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

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

458

2024.03.01

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

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

395

2023.09.04

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

316

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

752

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

93

2025.08.19

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

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

1415

2023.06.21

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

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

精品课程

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

共48课时 | 8.1万人学习

Git 教程
Git 教程

共21课时 | 3.1万人学习

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

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