91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

shell怎么記錄用戶的IP與命令

發布時間:2021-06-22 13:37:54 來源:億速云 閱讀:168 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關shell怎么記錄用戶的IP與命令,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

記錄輸入的命令

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

980 2017-05-29 20:17:37 cd -
981 2017-05-29 20:17:41 cat index.html
982 2017-05-29 20:20:11 vim index.html
983 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.log
986 2017-05-29 20:50:10 netstat -ntlp
987 2017-05-31 11:04:39 tmux a -t0
988 2017-05-31 11:15:42 exit
989 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 -nt
414 root@8.8.8.8 2017-06-02 22:03:38 netstat -ntpl
415 root@8.8.8.8 2017-06-03 14:17:09 history
416 root@8.8.8.8 2017-06-03 14:17:30 tmux ls
417 root@8.8.8.8 2017-06-03 14:17:34 tmux
418 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、時間和操作命令。

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

  1. 將命令寫到腳本,執行腳本;

  2. unset PROMPT_COMMAND變量。

關于“shell怎么記錄用戶的IP與命令”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌兰浩特市| 施甸县| 阿图什市| 抚松县| 城步| 祁连县| 靖远县| 沧源| 清河县| 墨竹工卡县| 神木县| 广河县| 武城县| 霍州市| 许昌市| 民丰县| 仪征市| 页游| 阜宁县| 郸城县| 温宿县| 桦川县| 枞阳县| 什邡市| 合作市| 朔州市| 轮台县| 昆明市| 墨竹工卡县| 鄯善县| 和政县| 台东市| 册亨县| 奉化市| 河津市| 甘肃省| 垦利县| 元朗区| 色达县| 孟津县| 大同市|