登录
首页 >  文章 >  linux

Linuxauditd审计日志配置教程

时间:2026-04-16 20:54:50 261浏览 收藏

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

Linux怎么配置auditd审计_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 auditdpkg -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_filenum_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学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>