0

0

Linux 系统入侵检测与日志分析

冷炫風刃

冷炫風刃

发布时间:2026-02-19 12:21:50

|

760人浏览过

|

来源于php中文网

原创

应交叉验证模块信息并检查内核符号、登录日志和auditd规则有效性:比对/proc/modules与lsmod,查/lib/modules下非标模块;用cat /proc/kallsyms | grep -v ' t ' | grep -e '(sys_|do_|entry_)'找异常重定向;核查auth.log中accepted与authorized_keys时间戳一致性;auditd需用-f exe=而非-f path=,且必须用aureport验证事件上报;journalctl须配合/var/log/auth.log或secure使用,优先用_comm=sshd。

linux 系统入侵检测与日志分析

怎么快速确认系统是否已被植入 rootkit

直接用 chkrootkitrkhunter 扫描,但它们只能发现已知签名——真正隐蔽的内核模块级 rootkit 很可能漏掉。更可靠的做法是交叉验证:比对 /proc/modules 输出和 lsmod 结果是否一致,检查 /lib/modules/$(uname -r)/kernel/ 下有没有非标准模块文件。

常见错误现象:lsmod 显示某个模块,但 find /lib/modules -name "*.ko" | xargs ls -l 找不到对应文件;或者 cat /proc/kallsyms | head -20 里有可疑符号名(如 hide_processfake_netdev)。

  • 优先运行 sudo cat /proc/kallsyms | grep -v ' t ' | grep -E '(sys_|do_|entry_)' 看是否有异常函数地址被重定向
  • 不要只信 rkhunter --checkall 的“OK”结果,它默认跳过内核模块校验,需手动加 --enable sysctl--enable kernel_modules
  • 若系统启用了 Secure Boot,insmod 加载未签名模块会失败,但攻击者可能已绕过或禁用它——检查 mokutil --sb-state

auth.log 里哪些登录行为必须立刻人工核查

不是所有失败登录都危险,重点盯住那些“成功绕过常规限制”的痕迹。比如 sshd 日志中出现 Accepted publickey 但对应用户主目录下 ~/.ssh/authorized_keys 文件时间戳早于上次安全审计日期,就极可能被篡改。

使用场景:日常巡检时用 grep "Accepted" /var/log/auth.log | tail -50 快速拉取最新成功登录,再逐条反查来源 IP 是否在白名单内。

  • 特别注意 invalid user 后紧跟着 Accepted 的记录——说明攻击者爆破到了一个真实存在的用户名+密码组合
  • session opened for user root by (uid=0) 出现在非运维时段,且没有对应 sudo 日志,大概率是直接 SSH 登录或 su 提权后残留
  • 同一 IP 在 1 分钟内触发多次 PAM 2.0 认证成功(查看 journalctl -u sshd | grep -E "PAM.*success"),可能是利用 PAM 模块漏洞绕过双因素

auditd 规则写错会导致日志爆炸或完全失效

auditd 不像 syslog 那样宽容,规则语法错一个字符(比如漏掉 -F 或多打空格),整个规则就会静默失效。最常踩的坑是想监控敏感命令执行,却只写了 -a always,exit -S execve -F path=/usr/bin/wget,结果什么都没捕获到——因为 execve 系统调用的路径参数实际是 argv[0],而 wget 常被软链接调用或通过绝对路径执行。

性能影响:开启 -a always,exit -S execve 全局监控,单机每秒超 200 次命令执行时,auditd 进程 CPU 占用可飙到 40%+,磁盘 I/O 也会明显升高。

  • 正确做法是用 -F exe=/usr/bin/wget 替代 -F path=,它匹配的是解释器真实路径,不受软链影响
  • 避免用 -w 监控整个 /etc,应拆成具体文件:如 -w /etc/passwd -p wa -k identity,否则每次 ls /etc 都会打点
  • 规则生效后务必运行 sudo aureport -m -ts today | head -10 验证是否真有事件上报,别只看 auditctl -l 列出的规则

用 journalctl 查历史登录会漏掉关键信息

journalctl -u sshd 默认只显示 systemd-journald 收到的日志,而 OpenSSH 在 UsePrivilegeSeparation yes(默认开启)时,子进程日志可能不经过 journald,尤其当连接被暴力破解中断、或认证方式为键盘交互式时。

兼容性影响:CentOS 7 默认用 rsyslog 转发 auth 日志,但 systemd-journal-gatewayd 在某些内核版本下无法解析二进制日志头,导致 journalctl --since "2024-01-01" -u sshd 返回空。

  • 必须同时查 /var/log/auth.log(Debian/Ubuntu)或 /var/log/secure(RHEL/CentOS),不能只依赖 journalctl
  • journalctl _COMM=sshd-u sshd 更准,因为后者只匹配 unit 名,前者匹配实际进程名,能捕获非 systemd 启动的 sshd 实例
  • 如果系统禁用了 persistent journal(Storage=volatile),重启后所有日志丢失——检查 ls /var/log/journal/ 是否为空目录

日志分析最难的从来不是工具用法,而是搞清一条记录背后到底发生了什么系统调用、哪个进程写的、有没有被重定向或伪造。别急着写告警规则,先花十分钟手工追一条可疑登录的完整调用链:从 auth.log 时间戳 → 对应的 audit log ID → 查 aureport -f -i -x sshd --start recent → 再反查该进程打开的文件描述符。这步省了,后面所有自动化都只是安慰剂。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
session失效的原因
session失效的原因

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

327

2023.10.17

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

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

773

2023.10.18

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

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

97

2025.08.19

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

71

2025.10.23

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

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

1520

2023.06.21

如何安装LINUX
如何安装LINUX

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

714

2023.06.29

linux find
linux find

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

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

791

2023.07.05

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.3万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

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

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