华为云服务器如何使用auditd记录Linux系统文件改动_云淘科技
auditd是Linux审计系统的用户空间组件,可以记录操作系统中的操作日志,包括文件读写、系统调用的记录等,出现问题可以用于审计。本文以CentOS 7.4 64位操作系统为例介绍auditd工具的安装和配置。
auditd相关工具与配置文件
相关命令:
auditctl : 即时控制审计守护进程的行为的工具,比如添加规则。
aureport : 查看和生成审计报告的工具。
ausearch : 查找审计事件的工具。
auditspd : 转发事件通知给其他应用程序,而不是写入到审计日志文件中。
autrace : 一个用于跟踪进程的命令,
相关配置文件:
/etc/audit/auditd.conf : auditd工具的配置文件
/etc/audit/rules.d/audit.rules:包含审核规则的文件
/etc/audit/audit.rules : 记录审计规则的文件。
操作步骤
安装auditd
执行以下命令安装auditd工具。
yum install -y auditd*
首次安装auditd 后,审计规则默认为空,可通过sudo auditctl -l命令查询。
执行以下命令查看运行状态。
service auditd status
图1 运行状态
配置审计规则
执行以下命令配置监控文件和目录的更改。
auditctl -w /etc/passwd -p rwxa
其中,
-w path : 指定要监控的路径,上面的命令指定了监控的文件路径 /etc/passwd
-p : 指定触发审计的文件/目录的访问权限
rwxa : 指定的触发条件,r-读取权限,w-写入权限,x-执行权限,a-属性
执行以下命令对/production目录的所有访问进行审计。
mkdir production
auditctl -w /production/
执行以下命令查看所有已配置的规则。
auditctl -l
-w /etc/passwd -p rwxa -w /production -p rwxa
规则添加后,执行以下命令查看审计日志。
ausearch -f /etc/passwd
图2 审计日志
图2显示文件未被改动。其中各参数含义如下:
time : 审计时间。
name : 审计对象
cwd : 当前路径
syscall : 相关的系统调用
auid : 审计用户ID
uid 和 gid : 访问文件的用户ID和用户组ID
comm : 用户访问文件的命令
exe : 上面命令的可执行文件路径
修改监控文件添加一个用户“test”。
useradd test
重新查看审计日志。
ausearch -f /etc/passwd
图3 查看变更后的审计日志
图3显示在指定的时间,/etc/passwd被root用户(uid=0, gid=0)在/root目录下修改。/etc/passwd文件是使用/usr/bin/sudo访问的。
此时,通过执行以下命令查看日志无内容。
ausearch -f /production
使用root账户修改目录权限,并重新查看审计日志。
chmod -R 777 /test/
ausearch -f /test/
执行以下命令查看审计报告。
aureport
图4 查看审计报告
执行以下命令查看授权失败的详细信息。
aureport -au
图5 查看授权失败信息
执行以下命令查看所有账户与修改相关的事件。
aureport -m
图6 查看账户修改相关事件
(可选)执行以下命令清空定义的规则。
auditctl -D
auditctl -l
图7 清空规则
内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家