0

0

linux审计守护进程是什么-auditd 命令使用与实例

P粉390130307

P粉390130307

发布时间:2025-08-05 08:52:28

|

581人浏览过

|

来源于https://www.runoob.com/linux/linux-comm-auditd.html

转载

linux审计守护进程是什么-auditd 命令使用与实例

Linux auditd 命令


auditd 是 Linux 系统上的审计守护进程,它是 Linux 审计框架的核心组件。auditd 的主要功能是监控和记录系统活动,包括:

  • 文件和目录访问
  • 系统调用
  • 用户登录/登出
  • 特权命令执行
  • 系统配置变更

这些审计日志对于系统安全监控、合规性检查和故障排查都非常重要。


auditd 核心组件

auditd 守护进程

持续运行的守护进程,负责收集和存储审计事件。

auditctl 工具

用于配置审计规则和控制审计系统的命令行工具。

ausearch 工具

用于查询审计日志的命令行工具。

aureport 工具

生成审计日志的汇总报告。


auditd 安装与启动

安装 auditd

在大多数 Linux 发行版上,auditd 通常已经预装。如果需要手动安装:

实例

# Ubuntu/Debian
sudo apt-get install auditd

# CentOS/RHEL
sudo yum install audit

启动和启用 auditd 服务

实例

# 启动服务
sudo systemctl start auditd

# 设置开机自启
sudo systemctl enable auditd

# 检查服务状态
sudo systemctl status auditd

auditd 配置文件

auditd 的主要配置文件位于

/etc/audit/auditd.conf
,包含以下重要参数:

参数 说明 默认值
@@######@@ 审计日志文件路径 @@######@@
@@######@@ 单个日志文件最大大小(MB) @@######@@
@@######@@ 保留的日志文件数量 @@######@@
@@######@@ 日志写入方式 @@######@@
@@######@@ 如果 flush=INCREMENTAL,多久同步一次 @@######@@

修改配置后需要重启服务:

log_file

auditctl 命令详解

/var/log/audit/audit.log
是配置审计规则的主要工具。

基本语法

max_log_file

常用选项

选项 说明
@@######@@ 列出当前所有规则
@@######@@ 删除所有规则
@@######@@ 显示审计系统状态
@@######@@ 从文件加载规则

规则类型

文件系统规则:监控文件/目录访问

实例

# 监控 /etc/passwd 文件的读写和属性修改
auditctl -w /etc/passwd -p rwxa -k passwd_access
  • 8
    :监控路径
  • num_logs
    :权限(r=读, w=写, x=执行, a=属性变更)
  • 5
    :关键词(用于日志过滤)

系统调用规则:监控特定系统调用

实例

# 监控所有使用 sudo 的命令
auditctl -a always,exit -F arch=b64 -S execve -F path=/usr/bin/sudo -k sudo_cmds
  • flush
    :动作和列表(always,exit 表示在退出系统调用时记录)
  • INCREMENTAL
    :过滤条件
  • freq
    :系统调用名称

用户规则:监控特定用户行为

Magic Write
Magic Write

Canva旗下AI文案生成器

下载

实例

# 监控UID大于500的用户删除文件
auditctl -a always,exit -S unlink -S unlinkat -S rename -S renameat -F auid>=500 -F auid!=4294967295 -k delete_files

审计日志分析

ausearch 命令

用于查询审计日志。

实例

# 查找特定关键词的日志
ausearch -k passwd_access

# 查找特定时间的日志
ausearch -ts today
ausearch -ts 10:00:00 -te 11:00:00

# 查找特定用户的日志
ausearch -ua 1000

aureport 命令

生成审计日志的汇总报告。

实例

# 生成用户登录报告
aureport -l

# 生成文件访问报告
aureport -f

# 生成所有事件的总结报告
aureport --summary

实际应用示例

示例1:监控敏感文件

实例

# 监控 /etc/shadow 文件
auditctl -w /etc/shadow -p wa -k shadow_mod

# 查看相关日志
ausearch -k shadow_mod | less

示例2:监控用户提权

实例

# 监控所有使用 sudo 或 su 的命令
auditctl -a always,exit -F arch=b64 -S execve -F path=/usr/bin/sudo -k priv_esc
auditctl -a always,exit -F arch=b64 -S execve -F path=/usr/bin/su -k priv_esc

# 生成提权报告
aureport --start today --event --summary -i | grep priv_esc

示例3:监控 SSH 登录

实例

# 监控 SSH 登录成功和失败
auditctl -a always,exit -F arch=b64 -S execve -F path=/usr/sbin/sshd -k sshd_login

# 查看 SSH 登录记录
ausearch -k sshd_login | grep 'acct="user"' | grep 'res=success'

最佳实践

合理设置日志轮转:确保日志不会填满磁盘

实例

# 编辑 /etc/audit/auditd.conf
max_log_file = 50
num_logs = 10

集中管理审计规则:将规则保存在文件中

实例

# 创建规则文件 /etc/audit/rules.d/my.rules
-w /etc/passwd -p wa -k passwd_changes
-w /etc/group -p wa -k group_changes

# 加载规则
auditctl -R /etc/audit/rules.d/my.rules

定期审查日志:设置 cron 任务定期分析日志

实例

# 每天生成报告并发送给管理员
0 0 * * * /usr/sbin/aureport --summary --start yesterday --end now | mail -s "Daily Audit Report" admin@example.com

保护审计日志:防止日志被篡改

实例

chmod 600 /var/log/audit/audit.log
chown root:root /var/log/audit/audit.log

常见问题排查

问题1:auditd 服务无法启动

解决方案

  1. 检查配置文件语法:
    20
  2. 查看系统日志:
    sudo systemctl restart auditd

问题2:没有生成审计日志

解决方案

  1. 确认服务正在运行:
    auditctl
  2. 检查规则是否加载:
    auditctl [选项] [规则]
  3. 验证内核支持:
    -l

问题3:日志文件过大

解决方案

  1. 调整日志大小和数量:修改
    -D
    中的
    -s
    -R 
  2. 设置日志压缩:添加
    -w
    到配置文件中

总结

auditd 是 Linux 系统强大的审计工具,通过合理配置可以:

  • 监控关键文件和目录的访问
  • 跟踪特权命令的使用
  • 记录用户登录和系统活动
  • 满足合规性要求

掌握 auditd 的使用对于系统管理员和安全专业人员至关重要,它可以帮助你更好地理解和保护你的 Linux 系统。


-p
-k
-a
-F
-s
auditd -f /etc/audit/auditd.conf
journalctl -u auditd
systemctl status auditd
auditctl -l
grep "audit" /boot/config-$(uname -r)
/etc/audit/auditd.conf
max_log_file
num_logs
compress = yes

相关专题

更多
Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

200

2023.10.12

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

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

1349

2023.06.21

如何安装LINUX
如何安装LINUX

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

702

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修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

572

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

545

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

297

2023.07.20

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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