欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年06月29日 10:50:25   作者:tlanyan  
這篇文章主要給大家介紹了關(guān)于shell是如何記錄用戶的IP與命令的相關(guān)資料,記錄用戶輸入過的命令使用history命令,而記錄用戶的IP可能稍復(fù)雜一些,需要的朋友們下面跟著小編一起來看看吧。

記錄輸入的命令

history命令可以查看用戶輸入過的命令,一個(gè)典型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。由于在用戶登入期間,會(huì)話不會(huì)斷開,所以只需獲取一次即可。

獲取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 

為了讓上述命令對(duì)所有用戶生效,可將其寫到/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文件中,用戶可隨時(shí)更改或者清除。為了統(tǒng)一管理用戶的命令記錄,我們希望用戶執(zhí)行命令后,執(zhí)行的命令能輸出到某個(gè)文件內(nèi)。達(dá)到這個(gè)目的需要 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中。任意輸入一個(gè)命令,然后打開/var/log/messages,會(huì)看到已經(jīng)記錄在案。/var/log/messages文件只有root有權(quán)限訪問,從而達(dá)到了記錄用戶IP和命令的目的。

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

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

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

  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é)

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

相關(guān)文章

  • 使用Bash Shell獲取文件名和目錄名的簡(jiǎn)單方法

    使用Bash Shell獲取文件名和目錄名的簡(jiǎn)單方法

    這篇文章主要介紹了使用Bash Shell獲取文件名和目錄名的簡(jiǎn)單方法,解析路徑是通常用Shell來實(shí)現(xiàn)的基本功能之一,需要的朋友可以參考下
    2015-07-07
  • shell實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)

    shell實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了shell實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Linux oracle數(shù)據(jù)庫自動(dòng)備份自動(dòng)壓縮腳本代碼

    Linux oracle數(shù)據(jù)庫自動(dòng)備份自動(dòng)壓縮腳本代碼

    這篇文章主要介紹了Linux oracle數(shù)據(jù)庫備份完成后可以自動(dòng)壓縮腳本代碼,大家參考使用
    2013-12-12
  • Linux nc命令使用示例

    Linux nc命令使用示例

    nc是netcat的簡(jiǎn)寫,是一個(gè)功能強(qiáng)大的網(wǎng)絡(luò)工具,有著網(wǎng)絡(luò)界的瑞士軍刀美譽(yù),nc命令在linux系統(tǒng)中實(shí)際命令是ncat,nc是軟連接到ncat,這篇文章主要介紹了Linux nc命令使用示例,需要的朋友可以參考下
    2023-03-03
  • Shell定時(shí)刪除指定時(shí)間之前的文件

    Shell定時(shí)刪除指定時(shí)間之前的文件

    這篇文章主要介紹了Shell定時(shí)刪除指定時(shí)間之前的文件,本文用來刪除一個(gè)月之前的備份文件,并加入到crontag定時(shí)刪除,需要的朋友可以參考下
    2014-12-12
  • Linux查看系統(tǒng)配置信息的命令詳解

    Linux查看系統(tǒng)配置信息的命令詳解

    Linux操作系統(tǒng)由Linux內(nèi)核和各種外圍程序組成, Linux內(nèi)核是一個(gè)特殊的軟件程序,用于實(shí)現(xiàn)CPU和內(nèi)存分配,進(jìn)程調(diào)度、設(shè)備驅(qū)動(dòng)等核心操作,本文給大家介紹了Linux查看系統(tǒng)配置信息的命令,需要的朋友可以參考下
    2024-04-04
  • Shell創(chuàng)建用戶并生成隨機(jī)密碼腳本分享

    Shell創(chuàng)建用戶并生成隨機(jī)密碼腳本分享

    這篇文章主要介紹了Shell創(chuàng)建用戶并生成隨機(jī)密碼腳本分享,本文生成的隨機(jī)密碼會(huì)比較復(fù)雜和實(shí)用,需要的朋友可以參考下
    2014-12-12
  • Shell腳本實(shí)現(xiàn)復(fù)制文件到多臺(tái)服務(wù)器的代碼分享

    Shell腳本實(shí)現(xiàn)復(fù)制文件到多臺(tái)服務(wù)器的代碼分享

    這篇文章主要介紹了Shell腳本實(shí)現(xiàn)復(fù)制文件到多臺(tái)服務(wù)器的代碼分享,用在多機(jī)集群環(huán)境中非常方便,需要的朋友可以參考下
    2014-09-09
  • shell腳本實(shí)戰(zhàn)-while循環(huán)語句

    shell腳本實(shí)戰(zhàn)-while循環(huán)語句

    這篇文章主要介紹了shell腳本實(shí)戰(zhàn)-while循環(huán)語句,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Linux查看GPU信息和使用情況的實(shí)現(xiàn)命令

    Linux查看GPU信息和使用情況的實(shí)現(xiàn)命令

    這篇文章主要介紹了Linux查看GPU信息和使用情況的實(shí)現(xiàn)命令,文中通過示例代碼和圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-12-12

最新評(píng)論