Logging root actions by capturing execve system calls
This article has last been updated at .
Capturing execve system calls and store them in the audit log
For compliance or security reasons you might want to capture all commands executed by the root user. Fortunately enough the Linux Audit Framework helps with capturing the right system calls and log it to the audit file.
Configure audit
To enable auditing, use the following two auditctl commands:
# auditctl -a exit,always -F arch=b64 -F euid=0 -S execve -k root-commands
# auditctl -a exit,always -F arch=b32 -F euid=0 -S execve -k root-commands
These commands will enable monitoring for the execve(2) system call (32-bit and 64-bit), but only when the effective user ID is 0, equal to the root user. Whenever you are logged in as root, or using sudo, it will log the related actions.
An alternative method is capturing all system calls for the root user, with a permission based filter. This means that all executes of files, write actions and changes to attributes are recorded.
auditctl -a exit,always -S all -F euid=0 -F perm=awx -k root-commands
Searching root activities
After logging the events for a while, we might want to search for them. By specifying a key (root-commands), you can quickly find them again using the ausearch command.
ausearch -k root-commands
This will perform a search through all audit entries, for which the key is root-commands.
Another option to capture administrative commands, is using Snoopy. Have a look at our previous blog post about Snoopy.