国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Linux > 正文

shell如何記錄用戶的IP與命令詳解

2019-10-26 18:53:05
字體:
來源:轉載
供稿:網友

記錄輸入的命令

history命令可以查看用戶輸入過的命令,一個典型history命令輸出如下:

980 2017-05-29 20:17:37 cd -981 2017-05-29 20:17:41 cat index.html982 2017-05-29 20:20:11 vim index.html983 2017-05-29 20:39:18 cd -984 2017-05-29 20:39:25 cd /var/log/nginx/985 2017-05-29 20:39:27 vim access.log986 2017-05-29 20:50:10 netstat -ntlp987 2017-05-31 11:04:39 tmux a -t0988 2017-05-31 11:15:42 exit989 2017-05-31 12:32:38 tmux a -t0

記錄IP

為了記錄用戶的IP,需要首先獲取用戶的登錄IP。由于在用戶登入期間,會話不會斷開,所以只需獲取一次即可。

獲取IP命令: who am i | awk '{print $NF}' | sed -e 's/[()]//g'

接著按照 username@ip datetime command 的格式記錄用戶的命令,這需要設置HISTTIMEFORMAT的值。獲取IP和設置命令格式結合起來:

IP=`who am i | awk '{print $NF}' | sed -e 's/[()]//g'`export HISTTIMEFORMAT=$USER@$IP %F %T 

為了讓上述命令對所有用戶生效,可將其寫到/etc/profile文件中。設置完畢后(可能需要重新登錄,或者用source命令重新加載/etc/profile),history命令輸出如下類似結果:

412 root@8.8.8.8 2017-06-02 22:03:27 netstat -nt414 root@8.8.8.8 2017-06-02 22:03:38 netstat -ntpl415 root@8.8.8.8 2017-06-03 14:17:09 history416 root@8.8.8.8 2017-06-03 14:17:30 tmux ls417 root@8.8.8.8 2017-06-03 14:17:34 tmux418 root@8.8.8.8 2017-06-03 14:17:49 tmux a -t0

history命令的內容保存在用戶的~/.bash_history文件中,用戶可隨時更改或者清除。為了統一管理用戶的命令記錄,我們希望用戶執行命令后,執行的命令能輸出到某個文件內。達到這個目的需要 PROMPT_COMMAND 環境變量的協助。

設置PROMPT_COMMAND將用戶的上一條命令log到syslog里面去:

export PROMPT_COMMAND="history 1 | logger -t cmd_log -p user.notice"

logger命令將信息輸出到/var/log/messages中。任意輸入一個命令,然后打開/var/log/messages,會看到已經記錄在案。/var/log/messages文件只有root有權限訪問,從而達到了記錄用戶IP和命令的目的。

如果你熟悉syslog,可以將命令記錄輸出到單獨的文件中。這需要在logger命令的-p選項中指定工具名稱和等級,例如local2.notice,然后編輯/etc/rsyslog.conf,將local2的信息輸出到單獨文件: local2.* /var/log/command.log,最后重啟rsyslog服務。

通過如上設定,即可在用戶無感知的情況下log用戶的IP、時間和操作命令。

對用戶來說,如何繞過?可以有兩種方式:

    將命令寫到腳本,執行腳本; unset PROMPT_COMMAND變量。

參考

https://askubuntu.com/questions/93566/how-to-log-all-bash-commands-by-all-users-on-a-server

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 扎兰屯市| 栖霞市| 长海县| 阳高县| 阿尔山市| 当阳市| 晋江市| 德令哈市| 常熟市| 华蓥市| 汉沽区| 中西区| 新竹市| 靖宇县| 德令哈市| 清镇市| 孟津县| 旌德县| 怀安县| 桂林市| 泽州县| 峨眉山市| 呼伦贝尔市| 贵州省| 萨嘎县| 万全县| 库车县| 景宁| 资中县| 怀化市| 古丈县| 九江市| 阿拉善盟| 八宿县| 卢氏县| 军事| 巴青县| 中方县| 越西县| 辽宁省| 溆浦县|