linux系统记录登录用户的所有操作

(base) root@lnpg \~# mkdir -p /db/user_audit

(base) root@lnpg \~# touch /db/user_audit/user_audit.log

(base) root@lnpg \~# chown nobody:nobody /db/user_audit/user_audit.log

(base) root@lnpg \~# chmod 002 /db/user_audit/user_audit.log

(base) root@lnpg \~# chattr +a /db/user_audit/user_audit.log

(base) root@lnpg \~# vi /etc/profile

/etc/profile

复制代码
export HISTORY_FILE=/db/user_audit/user_audit.log
export PROMPT_COMMAND='{ date "+%Y-%m-%d %T ##### $(who am i |awk "{print \$1\" \"\$2\" \"\$5}")  #### $(id|awk "{print \$1}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >> $HISTORY_FILE'

(base) root@lnpg \~# source /etc/profile

新开窗口做操作,可以看到实时的记录到用户的操作

(base) root@lnpg \~# tail -f /db/user_audit/user_audit.log

2025-10-20 11:57:07 ##### root pts/2 (10.168.20.66) #### uid=0(root) #### source /etc/profile

2025-10-20 11:57:33 ##### root pts/4 (10.168.20.66) #### uid=0(root) #### history|head

2025-10-20 11:57:42 ##### root pts/4 (10.168.20.66) #### uid=0(root) #### pwd

2025-10-20 11:57:49 ##### root pts/4 (10.168.20.66) #### uid=0(root) #### ls

2025-10-20 11:57:58 ##### root pts/4 (10.168.20.66) #### uid=54323(dmdba) #### exit

2025-10-20 11:58:05 ##### root pts/4 (10.168.20.66) #### uid=54323(dmdba) #### free -h

将文件名按日志保存写入:

复制代码
export CURRENT_DATE=$(date "+%Y-%m-%d")
export HISTORY_FILE=/db/user_audit/user_audit_${CURRENT_DATE}.log
export PROMPT_COMMAND='{ date "+%Y-%m-%d %T ##### $(who am i |awk "{print \$1\" \"\$2\" \"\$5}")  #### $(id|awk "{print \$1}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >> $HISTORY_FILE'


=========================

(base) [root@lnpg ~]# chmod -R 777 /db/user_audit/
chmod: changing permissions of '/db/user_audit/user_audit.log': Operation not permitted
(base) [root@lnpg ~]# ll /db/user_audit/*
-rwxrwxrwx 1 root   root    294 Oct 20 13:32 /db/user_audit/user_audit_2025-10-20.log
--------w- 1 nobody nobody 2347 Oct 20 13:31 /db/user_audit/user_audit.log
(base) [root@lnpg ~]# chown -R nobody:nobody /db/user_audit/
chown: changing ownership of '/db/user_audit/user_audit.log': Operation not permitted

https://chat.deepseek.com/share/x4feonhrk3w1vifbvq

相关推荐
用户3521802454751 小时前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
AlfredZhao2 小时前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
东坡白菜4 小时前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫4 小时前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq5 小时前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
用户9718356334668 小时前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
plainGeekDev8 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮8 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev8 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码9 小时前
Smart-Doc 的简单使用
java·后端·restful