Linuxauditd审计日志配置教程
时间:2026-04-16 20:54:50 261浏览 收藏
本文深入解析了Linux系统中auditd审计服务的完整配置与运维要点,直击新手常踩的“规则不生效”“日志为空”“参数不可见”“轮转后无法读取”等核心痛点,系统讲解了如何正确启用服务、重载规则(强调augenrules而非restart)、编写带arch和key的精准监控规则以捕获完整命令行、以及通过log_group安全放开日志访问权限;内容兼顾原理与实操,覆盖RHEL/CentOS/Fedora主流发行版及Docker精简环境的适配差异,是构建可靠、可审计、易维护Linux安全基线的实战指南。

auditd 服务没启动,日志根本不会写
auditd 不是开机默认启用的服务,哪怕装好了也处于 inactive 状态。不手动启动并设为开机自启,auditctl 加的规则、/etc/audit/rules.d/ 里的配置全都没用——日志文件 /var/log/audit/audit.log 会一直为空或只含启动失败记录。
- 检查状态:
systemctl status auditd,看到inactive (dead)就得动手 - 立即启用:
sudo systemctl start auditd - 设为开机自启:
sudo systemctl enable auditd - 注意:RHEL/CentOS 8+ 和 Fedora 默认用
auditd,但某些精简镜像(如部分 Docker 基础镜像)压根没装,先确认rpm -q audit或dpkg -l auditd
规则加在 /etc/audit/rules.d/ 但不生效
规则文件放对位置只是第一步,auditd 启动时只读取 /etc/audit/rules.d/*.rules 并加载进内核,但不会自动 reload。改完文件后必须显式重载,否则旧规则继续跑,新规则躺在磁盘上“吃灰”。
- 重载命令不是
systemctl restart auditd(它会清空当前规则),而是:sudo augenrules --load augenrules会合并所有.rules文件,生成/etc/audit/audit.rules,再用auditctl -R加载- 验证是否生效:
sudo auditctl -l查看当前已加载规则;sudo ausearch -m SYSCALL -ts recent看有没有捕获到操作 - 常见坑:文件名没以
.rules结尾(比如叫myaudit.conf),augenrules直接忽略
想监控用户执行的命令,但只看到 execve,看不到具体参数
audit 默认只记录系统调用入口(如 execve),不解析参数内容。要看到完整命令行(比如 rm -rf /tmp/*),必须开启 -F arch=b64(或 b32)并配合 -F key= 标记,否则日志里只有地址和长度,没法审计真实行为。
- 正确规则示例(监控所有 execve 调用并记录参数):
## /etc/audit/rules.d/cmd.rules -a always,exit -F arch=b64 -S execve -k command -a always,exit -F arch=b32 -S execve -k command
-F arch=b64必须明确指定,否则 64 位系统可能只匹配到部分调用;混合架构服务器(如带 32 位兼容库)建议两条都加-k command是关键标签,后续用ausearch -k command才能快速过滤- 性能影响:高频命令(如 shell 循环中反复调用
ls)会显著增加日志量,生产环境慎用全局execve监控
日志轮转后 audit.log 消失或权限异常
auditd 自带日志轮转(通过 auditd.conf 中的 max_log_file 和 num_logs 控制),但轮转后的压缩文件(audit.log.1.gz)默认属主是 root:root,且权限为 600。如果审计分析脚本或 SIEM 工具用非 root 用户读取,会直接失败。
- 修改轮转行为:编辑
/etc/audit/auditd.conf,调整compress(是否 gzip)、max_log_file(单文件上限)、num_logs(保留份数) - 若需放宽读取权限,不能直接改文件 umask,而应在
auditd.conf中设置:log_group = adm,再把分析用户加入adm组 - 轮转触发时机:达到
max_log_file或每日零点(取决于flush配置),不是按时间滚动,别误以为“每天一个新文件” - 重要提醒:
audit.log被轮转后,ausearch默认只查当前文件,查历史得加-if /var/log/audit/audit.log.1显式指定路径
audit 规则一旦加载进内核就脱离配置文件独立运行,重启 auditd 会清空规则再重载,但内核模块本身不支持热更新——这意味着线上临时加一条规则,必须走 auditctl -a,而不是只改文件。这点和 systemd 或 nginx 完全不同,容易误判“改了配置就生效”。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
416 收藏
-
391 收藏
-
151 收藏
-
364 收藏
-
108 收藏
-
310 收藏
-
297 收藏
-
164 收藏
-
213 收藏
-
477 收藏
-
445 收藏
-
457 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习