濮阳杆衣贸易有限公司

主頁 > 知識庫 > shell如何記錄用戶的IP與命令詳解

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

熱門標(biāo)簽:梧州防封電銷卡 上海機器人外呼系統(tǒng)哪家好 地圖標(biāo)注人員分布 昆明電銷機器人價格 益陽400電話申請辦理流程 春運地圖標(biāo)注app 怎么用百度地圖標(biāo)注坐標(biāo) 江西全自動外呼系統(tǒng)報價 400的電話一般從哪里辦理

記錄輸入的命令

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 的格式記錄用戶的命令,這需要設(shè)置HISTTIMEFORMAT的值。獲取IP和設(shè)置命令格式結(jié)合起來:

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

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

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命令的內(nèi)容保存在用戶的~/.bash_history文件中,用戶可隨時更改或者清除。為了統(tǒng)一管理用戶的命令記錄,我們希望用戶執(zhí)行命令后,執(zhí)行的命令能輸出到某個文件內(nèi)。達到這個目的需要 PROMPT_COMMAND 環(huán)境變量的協(xié)助。

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

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

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

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

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

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

  1. 將命令寫到腳本,執(zhí)行腳本;
  2. unset PROMPT_COMMAND變量。

參考

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

http://moper.me/ssh-audit-chats.html

http://zhu8337797.blog.163.com/blog/static/170617549201222912830483/

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 提高你工作效率的shell命令總結(jié)大全
  • shell腳本學(xué)習(xí)之調(diào)用腳本將文件打包zip的方法示例
  • Linux下NC反彈shell命令(推薦)
  • shell腳本實現(xiàn)多彩進度條
  • shell腳本實現(xiàn)多進程運行的方法示例
  • Shell腳本經(jīng)典之Fork炸彈的分析與預(yù)防
  • 詳解Linux Shell 實現(xiàn)一個獲取任意位數(shù)的隨機密碼的腳本

標(biāo)簽:懷化 惠州 贛州 新疆 亳州 九江 北京 河南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《shell如何記錄用戶的IP與命令詳解》,本文關(guān)鍵詞  shell,如何,記錄,用戶,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《shell如何記錄用戶的IP與命令詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于shell如何記錄用戶的IP與命令詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    天镇县| 沾益县| 万宁市| 体育| 西宁市| 阿尔山市| 西青区| 余庆县| 池州市| 玉屏| 镇康县| 木兰县| 名山县| 通化市| 县级市| 长海县| 旌德县| 修武县| 秭归县| 织金县| 江安县| 贵阳市| 得荣县| 思茅市| 玉林市| 介休市| 静宁县| 上林县| 固镇县| 长子县| 白银市| 九龙坡区| 特克斯县| 青川县| 双辽市| 剑川县| 五原县| 南阳市| 罗定市| 松潘县| 德钦县|