Install audit
The audit package is installed in Centos8 by default. If not installed, use the following command to add:
[root@localhost ~]# yum -y install audit
Audit configuration file / etc/audit/auditd.conf. This file contains default parameters to change the behavior of the auditd daemon.
Management audit services
After configuring auditd, start the service to collect audit information:
# service auditd start
The only reason to use the service command instead of systemctl is to record the user ID (UID) value correctly.
Set startup:
# systemctl enable auditd
Define audit rules
Using the auditctl tool, you can add audit rules to any system call you want. The rules are executed sequentially.
Next, define the monitoring rules. This rule tracks whether a file or directory is triggered by certain types of access, including read, write, execute, and property changes.
The syntax for defining rules is:
auditctl -w path_to_file -p permissions -k key_name
To audit user creation operations, first add monitoring to the / etc/passwd file to track write and attribute change access, and add a custom key to record all messages (this custom key can be used to filter log messages):
[root@localhost ~]# auditctl -w /etc/passwd -p wa -k user-modify
Next, add a new user. Doing so changes the / etc/passwd file:
[root@localhost ~]# useradd user01
Finally, check that auditd records the changes. By default, auditd stores logs in the / var/log/audit/audit.log file:
[root@localhost ~]# cat /var/log/audit/audit.log | grep user-modify
data:image/s3,"s3://crabby-images/0b043/0b04368f7be3eff9b5c75a66c7b613a13c228548" alt=""
Define persistent audit rules
To keep audit rules unchanged after reboot, add them to the / etc/audit/rules.d/audit.rules file.
Next, define persistence rules in the audit.rules file to monitor changes to the / etc/passwd file.
-w /etc/passwd -p wa -k user-modify
data:image/s3,"s3://crabby-images/0153f/0153fc5d97ce2129f6b4c6e64ae13adfcef74c25" alt=""
Save the file and reload the auditd daemon to make changes to the configuration in the rules file:
[root@localhost ~]# service auditd reload
data:image/s3,"s3://crabby-images/b5ed3/b5ed32674feac85ab19af182cf9ba69b701e74c8" alt=""
You can run auditctl -l to list rules:
[root@localhost ~]# auditctl -l -w /etc/passwd -p wa -k user-modify
data:image/s3,"s3://crabby-images/50805/50805308ae47b2b40dd8de619474dff88578f6fd" alt=""
Finally, adding a new user or changing the / etc/passwd file will start the audit. The changes are recorded in / var/log/audit/audit.log, and the rules still exist even if the system is restarted.
Search audit log
Use the ausearch tool to search the audit log. By default, it searches the / var/log/audit/audit.log file.
For example, according to the key_name searches log entries and searches for user modify related:
[root@localhost ~]# ausearch -i -k user-modify
data:image/s3,"s3://crabby-images/c1af6/c1af62b8ab9f3fcb68dd7b6b5898c296d4b51a8e" alt=""
Create audit report
Use the aureport tool to query and create audit reports based on audit logs.
[root@localhost ~]# aureport
data:image/s3,"s3://crabby-images/fc51c/fc51c78a7c13835319e1665a1d5ba5e22ea1ecf6" alt=""
To view a report on attempted authentication:
[root@localhost ~]# aureport -au Authentication Report ============================================ # date time acct host term exe success event ============================================ 1. 11/10/2021 23:42:19 root localhost.localdomain tty1 /usr/bin/login yes 81 2. 11/10/2021 23:44:08 root 192.168.43.1 ssh /usr/sbin/sshd yes 111 3. 11/10/2021 23:54:31 root 192.168.43.1 ssh /usr/sbin/sshd yes 76 4. 11/11/2021 00:44:30 root 192.168.43.1 ssh /usr/sbin/sshd yes 81 5. 11/11/2021 00:58:41 root 192.168.43.1 ssh /usr/sbin/sshd yes 131 6. 11/11/2021 01:13:12 root 192.168.43.1 ssh /usr/sbin/sshd no 156
data:image/s3,"s3://crabby-images/87e6d/87e6de6cf0cebe7e1198dbbcf04308fdccd391d2" alt=""
Where no represents authentication failure. yes means the verification is successful.
summary
In this article, you learned how to use auditctl to temporarily define auditd rules and permanently define them in the audit.rules file. Finally, the audit log is searched and the audit report is generated by using ausearch and aureport commands respectively.