0

0

Linux 日志如何发现安全问题?

冰川箭仙

冰川箭仙

发布时间:2026-01-24 11:20:01

|

664人浏览过

|

来源于php中文网

原创

最快速可靠的初筛信号是查/var/log/auth.log或/var/log/secure中密集的Failed password或Invalid user记录,需按系统区分路径,结合时间窗口、多源日志交叉验证及正确轮转归档确保分析准确性。

linux 日志如何发现安全问题?

直接查 /var/log/auth.log/var/log/secure 里的失败登录模式

绝大多数暴力破解攻击会在认证日志里留下密集的 Failed passwordInvalid user 记录,这是最快速、最可靠的初筛信号。但要注意:Debian/Ubuntu 用 /var/log/auth.log,RHEL/CentOS 默认用 /var/log/secure,别跑错文件。

  • 基础命令:grep "Failed password" /var/log/auth.log | awk '{print $(NF-3)}' | sort | uniq -c | sort -nr | head -10 —— 提取 IP 并统计频次,NF-3 是常见字段位置(OpenSSH 8.9+ 多在倒数第 4 字段),但不同版本可能偏移,建议先 head -5 /var/log/auth.log 看一眼实际结构
  • 加时间窗口才有效:单纯高频不等于攻击,得结合时间。比如 5 分钟内 ≥10 次失败才值得警惕,可用 journalctl -u sshd --since "5 minutes ago" | grep "Failed password" 替代静态文件,避免日志轮转导致漏查
  • 别只信 auth.loglastb -i 直读二进制 /var/log/btmp,不依赖 rsyslog 配置,且只存失败记录,更轻量;但需 root 权限,且重启后若未持久化 journal 可能丢失近期记录

awk 提取可疑 sudo 行为,而不是靠 grep 硬匹配

sudo 日志格式松散,grep "sudo:" 会混入大量 PATH=、环境变量等冗余行,真正危险的是非交互式提权或隐蔽 shell 启动。必须用 awk 做字段级过滤,否则容易误报或漏报。

  • 关键模式:awk '/sudo:.*COMMAND/{user=$1; tty=$3; cmd=$0; sub(/^.*COMMAND=/,"",cmd); print user, tty, cmd}' /var/log/auth.log | grep -v "^PATH="
  • 重点盯两个点:一是 tty=pts/0 却找不到对应 SSH 登录记录(用 last -i | grep "pts/0" 反查);二是命令含 /bin/bashnohupsh -i 等典型反弹 shell 特征
  • 注意用户字段陷阱:sudo -isudo su - 的日志里 $1 可能是 root,得往前翻找上一条带 USER=xxx 的 sudo 行才能确认原始操作者

别忽略 journalctlauditd 的互补性

journalctl 查服务级上下文(如 PAM 模块调用链、unit 启停),auditd 查内核级动作(如文件修改、execve 系统调用)。单用其一,会漏掉攻击链的关键一环。

Shopxp网上购物系统
Shopxp网上购物系统

Shopxp购物系统历经多年的考验,并在推出shopxp免费购物系统下载之后,收到用户反馈的各种安全、漏洞、BUG、使用问题进行多次修补,已经从成熟迈向经典,再好的系统也会有问题,在完善的系统也从在安全漏洞,该系统完全开源可编辑,当您下载这套商城系统之后,可以结合自身的技术情况,进行开发完善,当然您如果有更好的建议可从官方网站提交给我们。Shopxp网上购物系统完整可用,无任何收费项目。该系统经过

下载
  • 查可疑进程启动:journalctl -u sshd --since "2 hours ago" -o short-iso 看登录来源,再交叉查 ausearch -m execve -ts recent | aureport -f -i 看是否执行了非常规二进制
  • auditd 规则要精准:auditctl -a always,exit -F arch=b64 -S execve -F uid!=0 可捕获非 root 用户的命令执行,但别全开 -w /,I/O 压力大且日志爆炸
  • 默认 journal 大小受 /etc/systemd/journald.confSystemMaxUse 限制(常设为 50M),旧日志会被丢弃——别假设“所有历史都在”,长期审计必须配合 logrotate 归档或外发到 SIEM

轮转和归档不是运维的事,是分析准确性的前提

没配置好 logrotateauth.log.1.gz 里可能藏着上周的爆破记录,而你只盯着今天的文件白忙活;更糟的是,logrotate 配置错误(比如没 reload rsyslog)会导致日志写入中断,出现空白期。

  • 检查是否生效:logrotate -d /etc/logrotate.d/rsyslog(-d 是 debug 模式,不真执行,看输出是否含 rotating log
  • 关键配置项必须显式声明:create 640 syslog adm(确保新日志权限正确)、sharedscripts(多个日志共用 postrotate 脚本时防止重复 reload)、dateext(用日期而非数字后缀,方便按时间范围批量解压分析)
  • 自动化脚本里别硬编码路径:zcat /var/log/auth.log.*.gz 2>/dev/null | grep "Failed password" 比只查 auth.log 更全面,但注意 zcat 在无 gzip 文件时会报错,要用 2>/dev/null 屏蔽
真实攻击往往横跨多日志源、跨时间段、跨权限层级。最常被跳过的一步,是把 journalctl -u sshd 的登录 IP、lastb 的失败记录、ausearch 的 execve 调用、以及 logrotate 归档里的历史压缩包,做时间戳对齐——差一分钟,就可能断掉整个攻击链。

相关专题

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

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

185

2023.09.27

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

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

233

2023.09.22

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

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

437

2024.03.01

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

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

387

2023.09.04

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

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

1353

2023.06.21

如何安装LINUX
如何安装LINUX

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

704

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

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

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

777

2023.07.05

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

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

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